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

开源技术 软件

2020-09-18 14:01:21

vue3.0

2021-04-02 10:30:18

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开发管理系统

2022-11-28 17:21:24

2020-09-23 09:08:05

typescript

2022-11-18 08:32:02

Vue3.0开源项目

2024-03-29 09:07:15

Vue3.0开源项目

2022-11-30 15:33:39

Vue 3组件

2022-02-18 09:39:51

Vue3.0Vue2.0Script Set

2021-07-26 10:00:55

script-setuAPI前端

2021-09-28 09:30:18

uni-appVue 3.0uniCloud

2023-09-27 23:08:08

Web前端Vue.jsVue3.0

2024-04-10 08:45:51

Vue 3Proxy对象监测数据

2020-04-20 12:40:12

Vue 3.0 BetReact开发者

2020-11-06 08:54:43

Vue 3.0函数代码
点赞
收藏

51CTO技术栈公众号