日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Vue3.0插件執(zhí)行原理與實戰(zhàn)

一、編寫插件

1.1 包含install()方法的Object

Vue插件可以是一個包含install方法的Object對象,此時插件被調(diào)用時會調(diào)用install方法,如下所示:

分宜網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),分宜網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為分宜上千提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的分宜做網(wǎng)站的公司定做!

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

1.2 通過function的方式

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)用實例,所以其可以鏈式添加新的插件

三、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)了以下幾件事情:

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

名稱欄目:Vue3.0插件執(zhí)行原理與實戰(zhàn)
標題來源:http://www.5511xx.com/article/coheids.html