vue3??mixin?混入使用方法
vue 2 中采用選項(xiàng)式API 如: data、methods、watch、computed以及生命周期鉤子函數(shù)等等。
mixin
混入,提供了一種非常靈活的方式,來(lái)分發(fā) vue
組件中的可復(fù)用功能,一個(gè)mixin
對(duì)象可以包含任意組件選項(xiàng),當(dāng)組件使用 mixin
對(duì)象時(shí),所有的 mixin
對(duì)象的選項(xiàng)將被混入組件本身的選項(xiàng)。
一、mixin 如何使用 ?
通俗地講,mixin
對(duì)象把一些組件公用的選項(xiàng),如data
內(nèi)數(shù)據(jù),方法、計(jì)算屬性、生命周期鉤子函數(shù),單獨(dú)提取出來(lái),然后在組件內(nèi)引入,就可以與組件本身的選項(xiàng)進(jìn)行合并。
示例1:
<script> const myMixin = { data(){ return { num:520 } }, mounted(){ console.log('mixin mounted'); } } export default { mixins:[myMixin], } </script>
就相當(dāng)于:
<script> export default { data(){ return { num:520 } }, mounted(){ console.log('mixin mounted'); } } </script>
這樣做的好處就是可以把多個(gè)組件公共選項(xiàng)抽取到一個(gè) mixin 對(duì)象內(nèi),需要的時(shí)候直接引入就可以了。
二、mixin 使用時(shí)注意點(diǎn)
mixin
包含的選項(xiàng),同時(shí)組件內(nèi)也可以包含這些選項(xiàng),如果 mixin
中包含的選項(xiàng)中,有部分屬性相同怎么辦?如 mixin
和組件內(nèi)都存在一個(gè)同名方法時(shí),如何處理?或者都包含生命周期鉤子函數(shù)時(shí),它們的執(zhí)行順序誰(shuí)前誰(shuí)后呢?接下來(lái)我們就看看,使用 mixin 時(shí)應(yīng)該注意的點(diǎn)。
2.1、使用 mixin 對(duì)象時(shí),組件內(nèi)部和 mixin 包含相同選項(xiàng),如何處理呢?
示例2:mixin
對(duì)象和實(shí)例都包含data
選項(xiàng),內(nèi)部有兩個(gè)不同的變量
<template> <div> {{qdr}} - {{name}} </div> </template> <script> const myMixin = { data(){ return { name:'熱愛(ài)前端的小姐姐' } } } export default { mixins:[myMixin], data(){ return { qdr:"前端人" } } } </script>
運(yùn)行后,我們發(fā)現(xiàn)兩個(gè)變量都能使用,mixin
對(duì)象中的 data
與實(shí)例中的 data
選項(xiàng)進(jìn)行合并了。對(duì)于 methods
、computed
也是一樣的。
如果我們把上個(gè)實(shí)例中的兩個(gè)變量,修改成同名時(shí),會(huì)怎樣呢?
2.2、使用的 mixin 對(duì)象選項(xiàng) 和實(shí)例中的選項(xiàng)擁有相同的屬性該如何處理?
示例3:data
內(nèi)擁有相同的變量名 name
<template> <div> {{name}} </div> </template> <script> const myMixin = { data(){ return { name:'熱愛(ài)前端的小姐姐' } } } export default { mixins:[myMixin], data(){ return { name:"前端人" } } } </script>
運(yùn)行結(jié)果,name 值為 “前端人”。
屬性值相同時(shí),會(huì)選擇就近原則,優(yōu)先繼承實(shí)例內(nèi)的值,所以 mixin
對(duì)象的屬性會(huì)被實(shí)例中的屬性給覆蓋掉。
2.3、mixin 對(duì)象也可以添加生命周期鉤子函數(shù)
mixin 和 實(shí)例中 的那個(gè)優(yōu)先執(zhí)行呢?
示例4:mixin
加入生命周期鉤子函數(shù),以 mounted
為例
const myMixin = { mounted(){ console.log('mixin mounted'); } } export default { mixins:[myMixin], mounted(){ console.log('mounted'); } }
運(yùn)行結(jié)果:
我們發(fā)現(xiàn)生命周期函數(shù)會(huì)合并執(zhí)行,優(yōu)先執(zhí)行 mixin
中的, 然后再執(zhí)行實(shí)例中的。
三、mixin 自定義屬性
$options
用于當(dāng)前組件實(shí)例 的初始化選項(xiàng),需要在選項(xiàng)中包含自定義 property
時(shí)會(huì)有用處。
簡(jiǎn)單講,$options
用于在實(shí)例中調(diào)用 mixin
自定義屬性。
示例5:添加自定義屬性
const myMixin = { custom:'自定義屬性' } 在實(shí)例中使用: mounted(){ console.log(this.$options.custom); }
如果在實(shí)例中也包含一個(gè)同名自定義屬性時(shí),優(yōu)先級(jí)會(huì)作何處理呢?如果我們想控制優(yōu)先級(jí)又該如何處理呢?
四、合并策略
optionMergeStrategies
選項(xiàng)合并策略,使用 mixin
自定義屬性和實(shí)例中的屬性沖突時(shí),使用optionMergeStrategies
定義合并規(guī)則的,也就是優(yōu)先使用誰(shuí)的問(wèn)題。
使用規(guī)則:
app.config.optionMergeStrategies.propertyName=(mixinVal,appVal)=>{ return appVal || mixinVal // 確定優(yōu)先返回哪個(gè)屬性值 }
根據(jù)上述示例5,給實(shí)例中加 custom
屬性,運(yùn)行查看結(jié)果。
示例6:驗(yàn)證 mixin
和 實(shí)例 屬性優(yōu)先級(jí)
<script> const myMixin = { custom:'mixin custom', } export default { custom:'app custom', mixins:[myMixin], mounted(){ console.log(this.$options.custom); // 打印結(jié)果:app custom } } </script>
發(fā)現(xiàn),mixin
對(duì)象中的屬性值被實(shí)例中屬性值覆蓋掉了。我們可以借用上述的 optionMergeStrategies
屬性,修改 custom
的合并規(guī)則。
在 main.js 文件內(nèi)引入:
app.config.optionMergeStrategies.custom=(mixinVal,appVal)=>{ return mixinVal || appVal }
再次運(yùn)行之后,我們發(fā)現(xiàn)打印結(jié)果變成 mixin 中的屬性值了:
console.log(this.$options.custom); // 打印結(jié)果:mixin custom
五、全局配置 mixin
如果項(xiàng)目中有多個(gè)組件復(fù)用某些選項(xiàng)時(shí),我們可以通過(guò)全局使用 mixin
對(duì)象。一個(gè)實(shí)例也可以引入多個(gè) mixin
對(duì)象。
語(yǔ)法如下:
app.mixin([ {}, {}, {} ])
到此這篇關(guān)于 vue3 mixin 混入使用方法的文章就介紹到這了,更多相關(guān) vue3 mixin 混入內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
粘貼可用的element-ui validateField局部校驗(yàn)
這篇文章主要為大家介紹了粘貼可用element-ui中validateField局部校驗(yàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01在Vue 3中使用OpenLayers讀取WKB數(shù)據(jù)并顯示圖形效果
WKB作為一種緊湊的二進(jìn)制格式,在處理和傳輸空間數(shù)據(jù)時(shí)具有明顯優(yōu)勢(shì),本文介紹了如何在Vue 3中使用OpenLayers讀取WKB格式的空間數(shù)據(jù)并顯示圖形,感興趣的朋友一起看看吧2024-12-12vue-router2.0 組件之間傳參及獲取動(dòng)態(tài)參數(shù)的方法
下面小編就為大家?guī)?lái)一篇vue-router2.0 組件之間傳參及獲取動(dòng)態(tài)參數(shù)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11淺談使用mpvue開(kāi)發(fā)小程序需要注意和了解的知識(shí)點(diǎn)
這篇文章主要介紹了淺談使用mpvue開(kāi)發(fā)小程序需要注意和了解的知識(shí)點(diǎn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05vue-router路由跳轉(zhuǎn)問(wèn)題 replace
這篇文章主要介紹了vue-router路由跳轉(zhuǎn)問(wèn)題 replace,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09Vue如何獲取new Date().getTime()時(shí)間戳
在Web開(kāi)發(fā)中,前端使用Vue.js獲取的是毫秒級(jí)時(shí)間戳,而PHP后端則是秒級(jí)時(shí)間戳,處理此類問(wèn)題時(shí),需要將PHP的時(shí)間戳乘以1000轉(zhuǎn)換為毫秒級(jí),以保證數(shù)據(jù)的一致性和正確的邏輯判斷2024-10-10vue-treeselect(適配Vue3.2)及Element-plus的TreeSelect組件使用
這篇文章主要介紹了vue-treeselect(適配Vue3.2)及Element-plus的TreeSelect組件使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05vue中使用el-table組件checkbox進(jìn)行分頁(yè)多選,回顯、切換分頁(yè)記住上一頁(yè)所勾選和取消的選項(xiàng)(示例代碼)
這篇文章主要介紹了vue中使用el-table組件checkbox進(jìn)行分頁(yè)多選,回顯、切換分頁(yè)記住上一頁(yè)所勾選和取消的選項(xiàng)本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12