亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3.0插件執(zhí)行原理與實(shí)戰(zhàn)

 更新時(shí)間:2022年02月07日 14:27:46   作者:前端點(diǎn)線(xiàn)  
這篇文章主要介紹了Vue3.0插件執(zhí)行原理與實(shí)戰(zhàn),Vue項(xiàng)目能夠使用很多插件來(lái)豐富自己的功能Vue-Router、Vuex等,節(jié)省了我們大量的人力和物力,下面我們就一起來(lái)了解Vue3.0插件的原理吧,需要的小伙伴可以參考一下

一、編寫(xiě)插件

Vue項(xiàng)目能夠使用很多插件來(lái)豐富自己的功能,例如Vue-Router、Vuex……,這么多插件供我們使用,節(jié)省了我們大量的人力和物力,那這些插件是開(kāi)發(fā)出來(lái)的呢?是不是我們自己也想擁有一個(gè)屬于自己的vue插件,下面就展示一下如何寫(xiě)一個(gè)自己的Vue插件。

1.1 包含install()方法的Object

Vue插件可以是一個(gè)包含install方法的Object對(duì)象,此時(shí)插件被調(diào)用時(shí)會(huì)調(diào)用install方法,

如下所示:

export default {
    // 接收兩個(gè)參數(shù)
    // app: 應(yīng)用上下文的實(shí)例
    // options:插件輸入的選項(xiàng)
    install: (app, options) => {
        console.log('app', app);
        console.log('options', options);
        // 做一些處理
        // ……
    }
}

1.2 通過(guò)function的方式

Vue插件也可以是一個(gè)function函數(shù),此時(shí)插件被調(diào)用時(shí)會(huì)調(diào)用function函數(shù)本身,

如下所示:

export default function TestPlugin(app, options) {
    console.log('app', app);
    console.log('options', options);
}

二、使用插件

上述已經(jīng)闡述了如何編寫(xiě)自己的插件,插件編寫(xiě)完了之后就需要使用這些插件了,那這些插件應(yīng)該如何使用呢?其實(shí)用起來(lái)很簡(jiǎn)單,應(yīng)用上下文的實(shí)例上提供了對(duì)應(yīng)的use方法。

app.use(plugin, [options]); // 返回一個(gè)應(yīng)用實(shí)例,所以其可以鏈?zhǔn)教砑有碌牟寮?/pre>

三、app.use()是如何執(zhí)行插件的

為什么app.use()可以使用這些插件呢?本著“知其然而知其所以然”的精神,一起來(lái)扒一扒為什么。如下是對(duì)應(yīng)的源碼:

function createApp(rootComponent, rootProps = null) {
    // ……
    const installedPlugins = new Set();
    const app = (context.app = {
        // ……
        use(plugin, ...options) {
            if (installedPlugins.has(plugin)) {
                warn(`Plugin has already been applied to target app.`);
            }
            else if (plugin && shared.isFunction(plugin.install)) {
                installedPlugins.add(plugin);
                plugin.install(app, ...options);
            }
            else if (shared.isFunction(plugin)) {
                installedPlugins.add(plugin);
                plugin(app, ...options);
            }
            else {
                warn(`A plugin must either be a function or an object with an "install" ` +
                    `function.`);
            }
            return app;
        },
        // ……
    });
    return app;
};

上述代碼讀起來(lái)很簡(jiǎn)單,其實(shí)現(xiàn)了以下幾件事情:

  • 利用Set結(jié)構(gòu)存儲(chǔ)插件,當(dāng)存在該插件時(shí)拋出異常;
  • 通過(guò)判斷是否存在install方法或是否是函數(shù),執(zhí)行對(duì)應(yīng)的插件;
  • 執(zhí)行插件時(shí)將app上下文實(shí)例和options作為參數(shù)傳入;

 到此這篇關(guān)于Vue3.0插件執(zhí)行原理與實(shí)戰(zhàn)的文章就介紹到這了,更多相關(guān)Vue插件執(zhí)行原理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論