首頁 > web前端 > Vue.js > vue mixins是什麼

vue mixins是什麼

coldplay.xixi
發布: 2020-12-01 15:53:39
原創
2667 人瀏覽過

vue mixins是一種分發Vue元件中可重複使用功能的非常靈活的方式,混合物件可以包含任意元件選項,當元件使用混合物件時,所有混合物件的選項將被混入該元件本身的選項。

vue mixins是什麼

本教學操作環境:windows7系統、Vue2.9.6版,此方法適用於所有品牌電腦。

mixins

混合 (mixins) 是一種分發 Vue 元件中可重複使用功能的非常靈活的方式。

混合物件可以包含任意元件選項。

當元件使用混合物件時,所有混合物件的選項將被混入該元件本身的選項。

mixins理解

元件在引用後相當於在父元件內開闢了一塊單獨的空間,來根據父元件props過來的值進行對應的操作,單本質上兩者還是涇渭分明,相對獨立。

而mixins則是在引入元件之後,則是將元件內部的內容如data等方法、method等屬性與父元件對應內容合併。相當於在引入後,父組件的各種屬性方法都被擴充了。

單純元件參考:

父元件子元件>>>父元件子元件

mixins:

父元件子元件> >> new父元件

有點像是註冊了vue的公用方法,可以綁定在多個元件或多個Vue物件實例中使用。另一點,類似於在原型物件中註冊方法,實例物件即組件或Vue實例物件中,仍然可以定義相同函數名的方法進行覆蓋,有點像子類別和父類別的感覺。

mixins的使用

方法的複用

html

<div id="app">
    <child></child>
    <kid></kid>
</div>
登入後複製

js

Vue.component(&#39;child&#39;,{
    template:`<h1 @click="foo">child component</h1>`,
    methods:{
        foo(){
            console.log(&#39;Child foo()&#39;+this.msg++)
        }
    }
})
 
Vue.component(&#39;kid&#39;,{
    template:`<h1 @click="foo">kid component</h1>`,
    methods:{
        foo(){
            console.log(&#39;Kid foo()&#39;+this.msg++)
        }
    }
})
登入後複製

在使用mixins之前,在兩個不同的元件的元件中呼叫foo方法,需要重複定義,倘若方法比較複雜,程式碼會更加冗餘。若借助mixins,變得十分簡單:

let mixin={
    data(){
        return{
            msg:1
        }
    },
    methods:{
        foo(){
            console.log(&#39;hello from mixin!----&#39;+this.msg++)
        }
    }
}
var child=Vue.component(&#39;child&#39;,{ 
        template:`<h1 @click="foo">child component</h1>`, 
        mixins:[mixin]
})
Vue.component(&#39;kid&#39;,{ 
        template:`<h1 @click="foo">kid component</h1>`, 
        mixins:[mixin]
})
登入後複製

雖然此處,兩個元件用可以透過this.msg引用mixins中定義的msg,但是,小編嘗試過,兩個元件引用的並不是同一個msg,而是各自創造了一個新的msg。如果在元件中定義相同的data,則此處會引用元件中的msg,而非mixins中的。

以上是vue mixins是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
javascript - Vue 未定義
來自於 1970-01-01 08:00:00
0
0
0
javascript - 如何在vue-router中存取VUE實例?
來自於 1970-01-01 08:00:00
0
0
0
javascript - vue-for-idea
來自於 1970-01-01 08:00:00
0
0
0
沒看過VUE的專案實戰
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板