91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue3.0插件執行原理是什么

發布時間:2022-02-07 14:44:14 來源:億速云 閱讀:201 作者:iii 欄目:開發技術

這篇文章主要介紹“Vue3.0插件執行原理是什么”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Vue3.0插件執行原理是什么”文章能幫助大家解決問題。

    一、編寫插件

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

    1.1 包含install()方法的Object

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

    如下所示:

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

    1.2 通過function的方式

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

    如下所示:

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

    二、使用插件

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

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

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

    為什么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;
    };

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

    • 利用Set結構存儲插件,當存在該插件時拋出異常;

    • 通過判斷是否存在install方法或是否是函數,執行對應的插件;

    • 執行插件時將app上下文實例和options作為參數傳入;

    關于“Vue3.0插件執行原理是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    vue
    AI

    长兴县| 肇东市| 环江| 诸城市| 灵丘县| 富锦市| 桐庐县| 水富县| 南昌市| 恭城| 潍坊市| 吴忠市| 望奎县| 加查县| 青田县| 渑池县| 稻城县| 西吉县| 新乐市| 静乐县| 金门县| 修武县| 平原县| 建阳市| 金坛市| 广昌县| 穆棱市| 宁河县| 汉阴县| 会泽县| 贺州市| 双鸭山市| 班玛县| 平果县| 高淳县| 平定县| 余庆县| 怀远县| 华蓥市| 历史| 玉溪市|