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

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

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

一、編寫插件

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

1.1 包含install()方法的Object

Vue插件可以是一個包含install方法的Object對象,此時插件被調用時會調用install方法,

如下所示:

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

1.2 通過function的方式

Vue插件也可以是一個function函數(shù),此時插件被調用時會調用function函數(shù)本身,

如下所示:

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

二、使用插件

上述已經闡述了如何編寫自己的插件,插件編寫完了之后就需要使用這些插件了,那這些插件應該如何使用呢?其實用起來很簡單,應用上下文的實例上提供了對應的use方法。

app.use(plugin, [options]); // 返回一個應用實例,所以其可以鏈式添加新的插件

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

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

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;
};

上述代碼讀起來很簡單,其實現(xiàn)了以下幾件事情:

  • 利用Set結構存儲插件,當存在該插件時拋出異常;
  • 通過判斷是否存在install方法或是否是函數(shù),執(zhí)行對應的插件;
  • 執(zhí)行插件時將app上下文實例和options作為參數(shù)傳入;

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

相關文章

  • Vue Element-ui實現(xiàn)樹形控件節(jié)點添加圖標詳解

    Vue Element-ui實現(xiàn)樹形控件節(jié)點添加圖標詳解

    這篇文章主要為大家介紹了Element-ui實現(xiàn)樹形控件節(jié)點添加圖標,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Vue3使用時應避免的10個錯誤總結

    Vue3使用時應避免的10個錯誤總結

    Vue?3已經穩(wěn)定了相當長一段時間了。許多代碼庫都在生產環(huán)境中使用它,其他人最終都將不得不遷移到Vue?3。我現(xiàn)在有機會使用它并記錄了我的錯誤,下面這些錯誤你可能想要避免
    2023-03-03
  • vue2從數(shù)據變化到視圖變化之diff算法圖文詳解

    vue2從數(shù)據變化到視圖變化之diff算法圖文詳解

    這篇文章主要介紹了vue2從數(shù)據變化到視圖變化之diff算法圖文詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • 基于Vue3實現(xiàn)一個簡單的方位動畫

    基于Vue3實現(xiàn)一個簡單的方位動畫

    這篇文章主要為大家詳細介紹了如何基于Vue3實現(xiàn)一個簡單的方位動畫,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-02-02
  • Vue3 的ref和reactive的用法和區(qū)別示例解析

    Vue3 的ref和reactive的用法和區(qū)別示例解析

    ref和reactive是Vue3中用來實現(xiàn)數(shù)據響應式的API,一般情況下,ref定義基本數(shù)據類型,reactive定義引用數(shù)據類型,本文給大家介紹Vue3 的ref和reactive的用法和區(qū)別,感興趣的朋友一起看看吧
    2023-10-10
  • vue項目使用js監(jiān)聽瀏覽器關閉、刷新及后退事件的方法

    vue項目使用js監(jiān)聽瀏覽器關閉、刷新及后退事件的方法

    這篇文章主要給大家介紹了關于vue項目使用js監(jiān)聽瀏覽器關閉、刷新及后退事件的相關資料,文中通過代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • vue選擇下拉框動態(tài)變化表單方式

    vue選擇下拉框動態(tài)變化表單方式

    這篇文章主要介紹了vue選擇下拉框動態(tài)變化表單方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue 中 onclick和@click區(qū)別解析

    Vue 中 onclick和@click區(qū)別解析

    這篇文章主要介紹了Vue 中 onclick和@click區(qū)別,簡單點說就是onclick 只能觸發(fā) js的原生方法,不能觸發(fā)vue的封裝方法,@click 只能觸發(fā)vue的封裝方法,不能觸發(fā)js的原生方法,需要的朋友可以參考下
    2024-02-02
  • vue?過濾、模糊查詢及計算屬性?computed詳解

    vue?過濾、模糊查詢及計算屬性?computed詳解

    計算屬性是vue里面為了簡化在模板語法中對響應式屬性做計算而存在的,這篇文章主要介紹了vue?過濾、模糊查詢(計算屬性?computed),需要的朋友可以參考下
    2022-11-11
  • vue-video-player 斷點續(xù)播的實現(xiàn)

    vue-video-player 斷點續(xù)播的實現(xiàn)

    這篇文章主要介紹了vue-video-player 斷點續(xù)播的實現(xiàn),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02

最新評論