成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Vue3.0插件執行原理與實戰

開發 項目管理
Vue項目能夠使用很多插件來豐富自己的功能,例如Vue-Router、Vuex……,這么多插件供我們使用,節省了我們大量的人力和物力,那這些插件是開發出來的呢?

一、編寫插件

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

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

  1. 利用Set結構存儲插件,當存在該插件時拋出異常;
  2. 通過判斷是否存在install方法或是否是函數,執行對應的插件;
  3. 執行插件時將app上下文實例和options作為參數傳入;
責任編輯:姜華 來源: 前端點線面
相關推薦

2020-10-13 08:24:31

Vue3.0系列

2020-08-25 09:50:35

Vue3.0命令前端

2020-09-28 15:48:37

開源技術 軟件

2021-04-02 10:30:18

Vue3.0前端代碼

2020-09-18 14:01:21

vue3.0

2022-05-09 13:25:27

Vue3.0前端

2019-10-30 14:31:47

Vue 3.0數組響應

2021-01-12 15:54:03

Vue開發管理系統

2020-09-23 09:08:05

typescript

2022-11-28 17:21:24

2022-11-18 08:32:02

Vue3.0開源項目

2022-02-18 09:39:51

Vue3.0Vue2.0Script Set

2022-11-30 15:33:39

Vue 3組件

2024-03-29 09:07:15

Vue3.0開源項目

2021-09-28 09:30:18

uni-appVue 3.0uniCloud

2021-07-26 10:00:55

script-setuAPI前端

2023-09-27 23:08:08

Web前端Vue.jsVue3.0

2020-11-06 08:54:43

Vue 3.0函數代碼

2020-04-20 12:40:12

Vue 3.0 BetReact開發者

2021-02-18 08:19:21

Vue自定義Vue 3.0
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 看一级黄色毛片 | 岛国二区 | 欧美日韩在线免费观看 | 国产欧美精品一区二区 | 成人一区二区在线 | 国产精品久久久久无码av | 欧美一区二区三区在线观看 | 国产婷婷精品av在线 | 国产精品无 | 日日摸夜夜添夜夜添精品视频 | 久久精品天堂 | 秋霞av国产精品一区 | 日韩在线欧美 | 亚洲人成人一区二区在线观看 | 亚洲高清在线 | 精品一区二区免费视频 | 91免费在线 | 日韩欧美一二三区 | 久久99精品久久久久 | 九色在线视频 | 五月激情综合 | 青青草网站在线观看 | 国产精品一区在线播放 | 国产精品美女久久久久久免费 | 精品中文字幕一区二区三区 | 红桃视频一区二区三区免费 | 国产激情视频在线 | www.久久久.com | 国产国产精品 | 免费观看的av毛片的网站 | 国产伦精品一区二区三区精品视频 | 国产伦精品 | 中文字幕 欧美 日韩 | 日本高清精品 | 在线观看a视频 | 日韩精品在线看 | 中文字幕在线观看一区二区 | 影音先锋男 | 一级a性色生活片久久毛片波多野 | 91视在线国内在线播放酒店 | 国产精品精品视频一区二区三区 |