欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue混入mixin使用特點(diǎn)

 更新時(shí)間:2022年12月22日 10:21:25   作者:script~  
混入(mixin)提供了一種非常靈活的方式,來(lái)分發(fā)vue組件中的可復(fù)用功能。一個(gè)混入對(duì)象可以包含任意組件選項(xiàng)。當(dāng)組件使用混入對(duì)象時(shí),所有混入對(duì)象的選項(xiàng)將被“混合”進(jìn)入該組件本身的選項(xiàng)

什么是混入

混入 (mixin) : 是一種分發(fā)Vue組件中可復(fù)用功能的非常靈活的一種方式?;烊雽?duì)象(mixins)是一個(gè)js對(duì)象,它可以包含我們組件中script項(xiàng)中的任意功能選項(xiàng),如data、components、created、methods 、computed、watch等等。當(dāng)組件使用混入對(duì)象時(shí),所有混入對(duì)象的選項(xiàng)將被混入該組件本身的選項(xiàng)。

創(chuàng)建Mixins

在src目錄下創(chuàng)建一個(gè)mixins文件夾,文件夾下新建自己要定義的混入對(duì)象js文件。使用對(duì)象的形式來(lái)定義混入對(duì)象,在對(duì)象中可定義與vue組件一樣的data、components、created、methods 、computed、watch等屬性,并通過(guò)export導(dǎo)出該對(duì)象.

代碼示例: pageMixin.js

export const  pageMixin={
    data() {
        return {
            page: { // 分頁(yè)信息
                pageNo: 10, // 當(dāng)前頁(yè)
                limit: 10, // 每頁(yè)行數(shù)
                total: 0, // 列表總數(shù)量
            },        
            tableList: [], // 列表數(shù)據(jù)
            loading: false, // 加載列表數(shù)據(jù)的Loading
            PAGE_SIZES: [5, 10, 20, 30, 50, 90], // 每頁(yè)行數(shù)列表,用于切換每頁(yè)行數(shù)
            LAYOUT: "total, sizes, prev, pager, next, jumper" // Element表格組件中使用的功能
        }
    },
    methods: {
        // 查詢列表數(shù)據(jù)
        queryList() {},
        // 修改當(dāng)前頁(yè)
        handleCurrentChange(pageNo) {
            this.page.pageNo = pageNo;         
            this.queryList();
        },
        // 修改每頁(yè)行數(shù)
        handleSizeChange(limit) {
            this.page.pageNo = 1;
            this.page.limit = limit;
            this.queryList();
        },
    },
}

使用Mixins

在需要調(diào)用的組件頁(yè)面中引入pageMixin.js文件

import {pageMixin} from "@/mixins/pageMixin"
export default {
    mixins: [ pageMixin ],
    data() {
      return {    	
      }
    }        
}
  • 組件調(diào)用了混入對(duì)象故混入對(duì)象的選項(xiàng)會(huì)合并到當(dāng)前組件中。
  • 當(dāng)混入對(duì)象和組件含有同名選項(xiàng)時(shí),這些選項(xiàng)將以恰當(dāng)?shù)姆绞竭M(jìn)行“合并”。比如,數(shù)據(jù)對(duì)象在內(nèi)部會(huì)進(jìn)行遞歸合并,并在發(fā)生沖突時(shí)以組件數(shù)據(jù)優(yōu)先,即發(fā)生沖突會(huì)覆蓋混入對(duì)象的選項(xiàng)。

在組件(Home.vue)中使用

<template>
  <div class="home">
    <span>This is a Home page</span>
  </div>
</template>
<script>
import myMixins from "../mixins";   //導(dǎo)入混入(mixin)
export default {
  name: 'Home',
  mixins: [myMixins]     //使用混入(mixin)
}
</script>

注意觀察Home組件里面,并沒(méi)有任何的生命周期鉤子或者方法,但是打開頁(yè)面之后查看控制臺(tái),卻打印了內(nèi)容,這就是混入對(duì)象中的created鉤子中的console.log()。

mounted生命周期鉤子

<template>
  <div class="home">
    <span>This is a Home page</span>
  </div>
</template>
<script>
import myMixins from "../mixins";
export default {
  name: 'Home',
  mixins: [myMixins],
  mounted(){         
    this.hello()     //在該組件中并沒(méi)用定義hello方法,使用的是混入中的hello
  }
}
</script>

選項(xiàng)合并

當(dāng)組件和混入對(duì)象含有同名選項(xiàng)時(shí),這些選項(xiàng)將以恰當(dāng)?shù)姆绞竭M(jìn)行“合并”。數(shù)據(jù)對(duì)象在內(nèi)部會(huì)進(jìn)行遞歸合并,并在發(fā)生沖突時(shí)以組件數(shù)據(jù)優(yōu)先。

此時(shí),同名的created生命周期鉤子進(jìn)行了合并,合并為一個(gè)數(shù)組,因此都將被調(diào)用。另外,混入對(duì)象的鉤子將在組件自身鉤子之前調(diào)用。而methods中的hello方法因?yàn)闆_突,在合并時(shí)保留組件中的hello,即優(yōu)先當(dāng)前組件的選項(xiàng),因此打印的是“hello from Home!”。

值為對(duì)象的選項(xiàng),例如 methods、components 和 directives,將被合并為同一個(gè)對(duì)象。兩個(gè)對(duì)象鍵名沖突時(shí),取組件對(duì)象的鍵值對(duì)。

可復(fù)用性

開篇提過(guò),混入對(duì)象可成為一個(gè)可復(fù)用功能,我們?cè)诹硗獾慕M件中引入已定義的混入對(duì)象,可實(shí)現(xiàn)同樣的邏輯與功能。

如在另外一個(gè)組件About.vue使用該混入對(duì)象

<template>
  <div class="about">
    <span>This is an About page</span>
  </div>
</template>
<script>
import myMixins from "../mixins";
export default {
  name: "About",
  mixins: [myMixins]
};
</script>

混入對(duì)象中的console.log均被執(zhí)行了,實(shí)現(xiàn)了邏輯或功能的復(fù)用。

那么有個(gè)問(wèn)題,如果很多個(gè)組件同時(shí)使用同一個(gè)混入對(duì)象,這時(shí)候都要重復(fù)一個(gè)步驟,就是先導(dǎo)入混入對(duì)象,然后再使用,類似如下

<script>
import myMixins from "../mixins";
export default {
  mixins: [myMixins]
};
</script>

這樣未免有點(diǎn)繁瑣,且代碼冗余,此時(shí)我們可以使用全局混入來(lái)優(yōu)化這個(gè)問(wèn)題。

全局混入

混入也可以進(jìn)行全局注冊(cè)。使用時(shí)格外小心!一旦使用全局混入,它將影響每一個(gè)之后創(chuàng)建的 Vue 實(shí)例。使用恰當(dāng)時(shí),這可以用來(lái)為自定義選項(xiàng)注入處理邏輯。

在main.js中通過(guò)Vue.mixin()引入混入對(duì)象即可全局使用(作用于該Vue實(shí)例下的所有組件)

import mixin from './mixins';
Vue.mixin(mixin)

效果與在每個(gè)組件中單獨(dú)引入混入對(duì)象相同,這便是全局混入。

注意

請(qǐng)謹(jǐn)慎使用全局混入,因?yàn)樗鼤?huì)影響每個(gè)單獨(dú)創(chuàng)建的 Vue 實(shí)例 (包括第三方組件)。大多數(shù)情況下,只應(yīng)當(dāng)應(yīng)用于自定義選項(xiàng),就像上面示例一樣。推薦將其作為插件發(fā)布,以避免重復(fù)應(yīng)用混入。

到此這篇關(guān)于vue混入mixin使用特點(diǎn)的文章就介紹到這了,更多相關(guān)vue混入mixin內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue.js中 v-model 指令的修飾符詳解

    Vue.js中 v-model 指令的修飾符詳解

    v-model 指令默認(rèn)會(huì)在 input 事件中加載輸入框中的數(shù)據(jù)(中文輸入法中輸入拼音的過(guò)程除外)。這篇文章通過(guò)實(shí)例代碼給大家介紹Vue.js中 v-model 指令的修飾,感興趣的朋友跟隨小編一起看看吧
    2018-12-12
  • Laravel 如何在blade文件中使用Vue組件的示例代碼

    Laravel 如何在blade文件中使用Vue組件的示例代碼

    這篇文章主要介紹了Laravel 如何在blade文件中使用Vue組件,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • vue中在echarts里設(shè)置的定時(shí)器清除不掉問(wèn)題及解決

    vue中在echarts里設(shè)置的定時(shí)器清除不掉問(wèn)題及解決

    這篇文章主要介紹了vue中在echarts里設(shè)置的定時(shí)器清除不掉問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue3中使用router4 keepalive的問(wèn)題

    vue3中使用router4 keepalive的問(wèn)題

    這篇文章主要介紹了vue3中使用router4 keepalive的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue根據(jù)條件不同顯示不同按鈕的操作

    vue根據(jù)條件不同顯示不同按鈕的操作

    這篇文章主要介紹了vue根據(jù)條件不同顯示不同按鈕的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • 基于iview-admin實(shí)現(xiàn)動(dòng)態(tài)路由的示例代碼

    基于iview-admin實(shí)現(xiàn)動(dòng)態(tài)路由的示例代碼

    這篇文章主要介紹了基于iview-admin實(shí)現(xiàn)動(dòng)態(tài)路由的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue項(xiàng)目打包解決靜態(tài)資源無(wú)法加載和路由加載無(wú)效(404)問(wèn)題

    vue項(xiàng)目打包解決靜態(tài)資源無(wú)法加載和路由加載無(wú)效(404)問(wèn)題

    這篇文章主要介紹了vue項(xiàng)目打包,解決靜態(tài)資源無(wú)法加載和路由加載無(wú)效(404)問(wèn)題,靜態(tài)資源無(wú)法使用,那就說(shuō)明項(xiàng)目打包后,圖片和其他靜態(tài)資源文件相對(duì)路徑不對(duì),本文給大家介紹的非常詳細(xì),需要的朋友跟隨小編一起看看吧
    2023-10-10
  • vue3實(shí)現(xiàn)alert自定義的plugins方式

    vue3實(shí)現(xiàn)alert自定義的plugins方式

    這篇文章主要介紹了vue3實(shí)現(xiàn)alert自定義的plugins方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • vue調(diào)用高德地圖實(shí)例代碼

    vue調(diào)用高德地圖實(shí)例代碼

    本篇文章主要介紹了vue調(diào)用高德地圖實(shí)例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • Vue 組件(component)教程之實(shí)現(xiàn)精美的日歷方法示例

    Vue 組件(component)教程之實(shí)現(xiàn)精美的日歷方法示例

    組件是我們學(xué)習(xí)vue必須會(huì)的一部分,下面這篇文章主要給大家介紹了關(guān)于Vue 組件(component)教程之實(shí)現(xiàn)精美的日歷的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01

最新評(píng)論