Vue中Mixin&extends的詳細(xì)使用教程
認(rèn)識(shí)Mixin
目前我們使用組件化開(kāi)發(fā)方式來(lái)開(kāi)發(fā)應(yīng)用程序,但是在不同組件之間存在一些相同的代碼邏輯,此時(shí)我們希望對(duì)相同的代碼邏輯進(jìn)行抽取。
在vue2和vue3中都支持使用Mixin來(lái)解決,Mixin提供了一種非常靈活的方式,來(lái)分發(fā)Vue組件中的可復(fù)用功能,一個(gè)Mixin對(duì)象可以包含任何組件選項(xiàng),當(dāng)組件使用Mixin對(duì)象時(shí),所有Mixin對(duì)象的選項(xiàng)將被 混合 進(jìn)入該組件本身的選項(xiàng)中。
官方定義Mixin
Mixin 提供了一種非常靈活的方式,來(lái)分發(fā) Vue 組件中的可復(fù)用功能。一個(gè) mixin 對(duì)象可以包含任意組件選項(xiàng)。當(dāng)組件使用 mixin 對(duì)象時(shí),所有 mixin 對(duì)象的選項(xiàng)將被“混合”進(jìn)入該組件本身的選項(xiàng)。
項(xiàng)目中如何使用Mixin
在src文件夾下創(chuàng)建一個(gè)mixins文件夾
在demomixins.js文件下
export default { data() { return { msg:'mixins 中的data' } }, mounted() { console.log('mixins 中的mounted'); }, methods:{ foo() { console.log('mixins 中的methods'); } }, computed:{ message() { return 'mixin 中的computed' } } }
在Home.vue文件下
<template> <div class='home'> {{msg}}<br> {{message}}<br> <button @click="foo">點(diǎn)擊按鈕</button> </div> </template> <script> // 導(dǎo)入js文件 import demomixins from '@/mixins/demomixins.js' export default { name:'Home', data() { return { }; }, mixins:[demomixins], // 混入demomixins對(duì)象 mounted() { }, methods: {}, components:{}, }; </script>
雖然我們沒(méi)有在home.vue中定義msg變量、message計(jì)算屬性、foo方法,但是頁(yè)面中可以顯示。
Mixin的合并規(guī)則
如果Mixin對(duì)象中的選項(xiàng)和組件對(duì)象中的選項(xiàng)發(fā)生了沖突,那么Vue會(huì)如何操作呢?
<template> <div class='home'> {{msg}}<br> {{message}}<br> <button @click="foo">點(diǎn)擊按鈕</button> </div> </template> <script> // 導(dǎo)入 import demomixins from '@/mixins/demomixins.js' export default { name:'Home', data() { return { msg:'home 中的data' }; }, mixins:[demomixins], mounted() { console.log('home 中的mounted'); }, methods:{ foo() { console.log('home 中的methods'); } }, computed:{ message() { return 'home 中的computed' } } }; </script>
以上我們可以看出:
混入的對(duì)象中的msg屬性,和組件的msg屬性沖突,以組件的值優(yōu)先。組件中沒(méi)有的屬性,混入對(duì)象中的生效。
同名鉤子函數(shù)將會(huì)合并成一個(gè)數(shù)組,都會(huì)調(diào)用,混入函數(shù)先調(diào)用
值為對(duì)象的選項(xiàng),如methods,computed等,將會(huì)合并為一個(gè)新對(duì)象,如果鍵名沖突,組件的值優(yōu)先
全局混入Mixin
如果組件中的某些選項(xiàng),是所有的組件都需要擁有的,那么這個(gè)時(shí)候我們可以使用全局的mixin。一旦注冊(cè),那么全局混入的選項(xiàng)將會(huì)影響每一個(gè)組件
const app = createApp(App) app.mixin({ data() { return { msg:'global 中的data' } }, })
官方定義extends
允許一個(gè)組件擴(kuò)展到另一個(gè)組件,且繼承該組件選項(xiàng)。
extends類(lèi)似于mixin,相當(dāng)于繼承,但是只是繼承options Api中的內(nèi)容,不繼承template模板。
項(xiàng)目中使用extends
在components創(chuàng)建一個(gè)組件my.vue
<script> export default { data() { return { msg:'uu盤(pán)' }; } }; </script>
在Home.vue文件下
<template> <div class='home'> {{msg}} </div> </template> <script> // 導(dǎo)入 import my from '@/components/my' export default { name:'Home', extends:my, data() { return { }; }, }; </script>
在開(kāi)發(fā)中extends用的非常少,在Vue2中比較推薦大家使用Mixin,而在Vue3中推薦使用Composition API。
總結(jié)
到此這篇關(guān)于Vue中Mixin&extends詳細(xì)使用的文章就介紹到這了,更多相關(guān)Vue中Mixin&extends使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解vue中$nextTick和$forceUpdate的用法
這篇文章主要介紹了詳解vue中$nextTick和$forceUpdate的用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12詳解Vue.js iview實(shí)現(xiàn)樹(shù)形權(quán)限表(可擴(kuò)展表)
這篇文章主要介紹了詳解Vue.js iview實(shí)現(xiàn)樹(shù)形權(quán)限表(可擴(kuò)展表),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09詳解Vue開(kāi)發(fā)微信H5微信分享簽名失敗問(wèn)題解決方案
這篇文章主要介紹了詳解Vue開(kāi)發(fā)微信H5微信分享簽名失敗問(wèn)題解決方案,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08在vue使用clipboard.js進(jìn)行一鍵復(fù)制文本的實(shí)現(xiàn)示例
這篇文章主要介紹了在vue使用clipboard.js進(jìn)行一鍵復(fù)制文本的實(shí)現(xiàn)示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01