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

Vue混入與插件的使用介紹

 更新時(shí)間:2022年09月08日 11:28:02   作者:月光曬了很涼快  
這篇文章主要介紹了Vue混入與插件的使用,mixins(混入),官方的描述是一種分發(fā) Vue 組件中可復(fù)用功能的非常靈活的方式,mixins是一個(gè)js對象,它可以包含我們組件中script項(xiàng)中的任意功能選項(xiàng),如data、components、methods 、created、computed等等

1. 混入

概述:

混入(mixins)是一種分發(fā)Vue組件中可復(fù)用功能的非常靈活的方式?;烊雽ο罂梢园我饨M件選項(xiàng)。當(dāng)組件使用混入對象時(shí),所有混入對象的選項(xiàng)將被混入該組件本身的選項(xiàng)。

簡單來說,混入用于公共代碼復(fù)用。

混入分為:全局和局部。

混入的執(zhí)行順序:

<div id="app">
    <h3>{{name}}</h3>
    <hr>
    <h3>{{showName}}</h3>
    <hr>
    <div>{{run()}}</div>
</div>
<script>
    // 混入:用于公共代碼復(fù)用
    // 方式  全局  局部
    Vue.mixin({
        // data混入
        data() {
            return {
                name: '張三 -- 全局'
            }
        },
        // 計(jì)算屬性混入
        computed: {
            showName() {
                return 'abc -- 全局'
            }
        },
        methods: {
            run() {
                return 'run -- 全局'
            }
        },
        // 生命周期方法混入
        created() {
            console.log('created -- 全局');
        }
    })
    // 局部混入
    const mix = {
        data() {
            return {
                name: '張三 -- 局部'
            }
        },
        computed: {
            showName() {
                return 'abc -- 局部'
            }
        },
        methods: {
            run() {
                return 'run -- 局部'
            }
        },
        created() {
            console.log('created -- 局部');
        }
    }
    const vm = new Vue({
        el: '#app',
        data: {
            // name: '張三 -- 實(shí)例'
        },
        // 局部混入調(diào)用,可以調(diào)用 n 個(gè)
        mixins: [mix],
        methods: {
            run() {
                return 'run -- 實(shí)例'
            }
        },
        created() {
            console.log('created -- 實(shí)例');
        }
    })
</script>

注意:

  1. 混入的配置,可以把幾乎所有new Vue配置中的所有配置都能混入,但是el配置它不可以混入
  2. data配置,在混入方式中,只能寫函數(shù)的方式,且函數(shù)一定要返回一個(gè)對象,混入可能被調(diào)用多次,如果直接是對象的話,就會有污染(調(diào)用多次,引用地址卻不變,實(shí)例之間調(diào)用時(shí)不會互相影響)
  3. data混入的優(yōu)先級(對象屬性) 組件(實(shí)例) > 局部 > 全局 => 只會調(diào)用一個(gè)
  4. 生命周期方法,執(zhí)行順序 全局 -> 局部 --> 組件(實(shí)例) 依次執(zhí)行
  5. 方法依次執(zhí)行,屬性對應(yīng)的配置只執(zhí)行一次,data是例外

2. 插件

概述:

在vue中提供插件機(jī)制,可以通過它的要求來完成插件的封裝,運(yùn)用到項(xiàng)目中

語法:

Vue.use(函數(shù)|類|對象,[可選參數(shù)])

// 函數(shù)
// 函數(shù)名稱 plugin 可以更換
function plugin(Vue類,options可選參數(shù)){}
// 類
class Plugin {
	// 必須是靜態(tài)方法,且名稱必須為install
	static install(Vue類,options可選參數(shù)){}
}
// 調(diào)用靜態(tài)屬性:Plugin.install(Vue類,options可選參數(shù))
// 對象
const obj = {
	// 屬性名稱必須為 install
	install(Vue類,options可選參數(shù)){}
}

案例:

<div id="app">
    <h3 v-red>{{title}}</h3>
</div>
<script>
    // 它是就一個(gè)模塊
    function plugin(Vue, options) {
        console.log(options);
        // 這是一個(gè)指令
        Vue.directive('red', el => {
            el.style.cssText = 'color:red'
        })
        // 這是混入
        Vue.mixin({
            data() {
                return {
                    title: `() => console.log('run');`
                }
            },
            // 這是生命周期方法
            created() {
                this.title = options.title
                console.log('混入了');
            }
        })
        // 靜態(tài)屬性
        Vue.run = () => console.log('run');
        // 添加成員屬性
        Vue.prototype.play = () => console.log('play');
    }
    // 插入插件,可以插入?yún)?shù)
    Vue.use(plugin, { title: 'abc' })
    const vm = new Vue({
        el: '#app',
        data: {
        },
        created() {
            Vue.run()
            this.play()
        }
    })
</script>

插件封裝成類:

<div id="app">
    <h3 v-red>{{title}}</h3>
</div>
<script>
    class Plugin {
        // 它是就一個(gè)模塊
        static install(Vue, options) {
            console.log(options);
            Vue.directive('red', el => {
                el.style.cssText = 'color:red'
            })
            Vue.mixin({
                data() {
                    return {
                        title: `() => console.log('run');`
                    }
                },
                created() {
                    this.title = options.title
                    console.log('混入了');
                }
            })
            // 添加成員屬性
            Vue.prototype.run = () => console.log('run');
        }
    }
    // 插入插件
    Vue.use(Plugin, { title: 'abc' })
    const vm = new Vue({
        el: '#app',
        data: {
        },
        created() {
            this.run()
        }
    })
</script>

插件封裝成對象:

<div id="app">
    <h3 v-red>{{title}}</h3>
</div>
<script>
    const Plugin = {
        install(Vue, options) {
            console.log(options);
            Vue.directive('red', el => {
                el.style.cssText = 'color:red'
            })
            Vue.mixin({
                data() {
                    return {
                        title: `() => console.log('run');`
                    }
                },
                created() {
                    this.title = options.title
                    console.log('混入了');
                }
            })
            // 添加成員屬性
            Vue.prototype.run = () => console.log('run');
        }
    }
    // 插入插件
    Vue.use(Plugin, { title: 'abc' })
    const vm = new Vue({
        el: '#app',
        data: {
        },
        created() {
            this.run()
        }
    })
</script>

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

相關(guān)文章

  • vue項(xiàng)目中定義全局變量、函數(shù)的幾種方法

    vue項(xiàng)目中定義全局變量、函數(shù)的幾種方法

    這篇文章主要介紹了vue項(xiàng)目中定義全局變量、函數(shù)的幾種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Vue源碼分析之Vue實(shí)例初始化詳解

    Vue源碼分析之Vue實(shí)例初始化詳解

    這篇文章主要給大家介紹了關(guān)于Vue源碼分析之Vue實(shí)例初始化的相關(guān)資料,需要的朋友可以參考下
    2019-08-08
  • 一篇文章看懂Vue組合式API

    一篇文章看懂Vue組合式API

    眾所周知組合式API是一系列API的集合,使我們可以使用函數(shù)而不是聲明選項(xiàng)的方式書寫Vue組件,這篇文章主要給大家介紹了關(guān)于Vue組合式API的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • Vue3中emits與attrs的區(qū)別分析

    Vue3中emits與attrs的區(qū)別分析

    這篇文章主要給大家介紹了關(guān)于Vue3中emits與attrs區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-10-10
  • vue 解決uglifyjs-webpack-plugin打包出現(xiàn)報(bào)錯(cuò)的問題

    vue 解決uglifyjs-webpack-plugin打包出現(xiàn)報(bào)錯(cuò)的問題

    這篇文章主要介紹了vue 解決uglifyjs-webpack-plugin打包出現(xiàn)報(bào)錯(cuò)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue自定義全局Toast和Loading的實(shí)例詳解

    Vue自定義全局Toast和Loading的實(shí)例詳解

    這篇文章主要介紹了Vue自定義全局Toast和Loading,需要的朋友可以參考下
    2019-04-04
  • electron踩坑之remote of undefined的解決

    electron踩坑之remote of undefined的解決

    這篇文章主要介紹了electron踩坑之remote of undefined的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • Element-ui 滾動條美化的實(shí)現(xiàn)

    Element-ui 滾動條美化的實(shí)現(xiàn)

    本文主要介紹了Element-ui 滾動條美化的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能

    Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能

    這篇文章主要給大家介紹了Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能的代碼示例,文章通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的參幫助,需要的朋友可以參考下
    2023-11-11
  • 基于Vue 2.0的模塊化前端 UI 組件庫小結(jié)

    基于Vue 2.0的模塊化前端 UI 組件庫小結(jié)

    AT-UI 是一款基于 Vue.js 2.0 的輕量級、模塊化前端 UI 組件庫,主要用于快速開發(fā) PC 網(wǎng)站產(chǎn)品。下面通過本文給大家介紹Vue 2.0的模塊化前端 UI 組件庫,需要的朋友參考下吧
    2017-12-12

最新評論