您好,登錄后才能下訂單哦!
這篇文章主要介紹“Vue3.0插件執(zhí)行原理是什么”的相關(guān)知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強(qiáng),希望這篇“Vue3.0插件執(zhí)行原理是什么”文章能幫助大家解決問題。
Vue項目能夠使用很多插件來豐富自己的功能,例如Vue-Router
、Vuex……,這么多插件供我們使用,節(jié)省了我們大量的人力和物力,那這些插件是開發(fā)出來的呢?是不是我們自己也想擁有一個屬于自己的vue插件,下面就展示一下如何寫一個自己的Vue插件。
Vue插件可以是一個包含install
方法的Object
對象,此時插件被調(diào)用時會調(diào)用install方法,
如下所示:
export default { // 接收兩個參數(shù) // app: 應(yīng)用上下文的實例 // options:插件輸入的選項 install: (app, options) => { console.log('app', app); console.log('options', options); // 做一些處理 // …… } }
Vue插件也可以是一個function
函數(shù),此時插件被調(diào)用時會調(diào)用function
函數(shù)本身,
如下所示:
export default function TestPlugin(app, options) { console.log('app', app); console.log('options', options); }
上述已經(jīng)闡述了如何編寫自己的插件,插件編寫完了之后就需要使用這些插件了,那這些插件應(yīng)該如何使用呢?其實用起來很簡單,應(yīng)用上下文的實例上提供了對應(yīng)的use方法。
app.use(plugin, [options]); // 返回一個應(yīng)用實例,所以其可以鏈?zhǔn)教砑有碌牟寮?/pre>三、app.use()是如何執(zhí)行插件的
為什么
app.use()
可以使用這些插件呢?本著“知其然而知其所以然”的精神,一起來扒一扒為什么。如下是對應(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; };上述代碼讀起來很簡單,其實現(xiàn)了以下幾件事情:
利用Set
結(jié)構(gòu)存儲插件,當(dāng)存在該插件時拋出異常;
通過判斷是否存在install
方法或是否是函數(shù),執(zhí)行對應(yīng)的插件;
執(zhí)行插件時將app
上下文實例和options
作為參數(shù)傳入;
關(guān)于“Vue3.0插件執(zhí)行原理是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點(diǎn)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。