Vue使用mixin分發(fā)組件的可復用功能
vue創(chuàng)建高階組件的實現(xiàn)不夠react優(yōu)雅,但那是vue和react的設計思想導致的。在react中一切都是函數(shù),而在vue中,組件最終都是函數(shù),但在開發(fā)時可以是JSON對象,而且每個vue組件要注意三個點:props、events和slots,就是這三個導致vue創(chuàng)建高階組件時要傳入相應的屬性,較react要復雜。
vue官方推薦使用mixins來完成高階組件的功能,如果對vue實現(xiàn)高階組件有興趣的話推薦看[vue實現(xiàn)高階組件][1]
下面是vue官網(wǎng)使用mixins的例子:
// 定義一個混入對象
var myMixin = {
created: function () {
this.hello()
},
methods: {
hello: function () {
console.log('hello from mixin!')
}
}
}
// 定義一個使用混入對象的組件
var Component = Vue.extend({
mixins: [myMixin]
})
var component = new Component() // => "hello from mixin!"
每個vue組件有mixins屬性接收mixin數(shù)組,但由于mixin與組件,mixin與mixin之間存在屬性命名沖突的問題,vue解決這個的方式是:
1 數(shù)據(jù)對象在內(nèi)部會進行遞歸合并,并在發(fā)生沖突時以組件數(shù)據(jù)優(yōu)先。
2 值為對象的選項,例如 methods、components 和 directives,將被合并為同一個對象。兩個對象鍵名沖突時,取組件對象的鍵值對。
3 Vue.extend()和new Vue()創(chuàng)建的組件,解決上述的命名沖突的方案是一樣的。
總結(jié)
以上所述是小編給大家介紹的Vue使用mixin分發(fā)組件的可復用功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
相關文章
vue element upload實現(xiàn)圖片本地預覽
這篇文章主要為大家詳細介紹了vue element upload實現(xiàn)圖片本地預覽,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08
Vue-cli集成axios請求出現(xiàn)CORS跨域問題及解決
這篇文章主要介紹了Vue-cli集成axios請求出現(xiàn)CORS跨域問題及解決方案,具有很好的參考價值,希望對大家有所幫助,2023-10-10
Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式
這篇文章主要介紹了Vue-cli中post請求發(fā)送Json格式數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue中在data里面調(diào)用method方法的實現(xiàn)
這篇文章主要介紹了Vue中在data里面調(diào)用method方法的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06
解決vue+router路由跳轉(zhuǎn)不起作用的一項原因
這篇文章主要介紹了解決vue+router路由跳轉(zhuǎn)不起作用的一項原因,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07

