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插件执行原理与实战的文章就介绍到这了,更多相关Vue插件执行原理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue-cli3自动消除console.log()的调试信息方式
这篇文章主要介绍了vue-cli3自动消除console.log()的调试信息方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-10-10Ant Design-vue 解决input前后空格问题(推荐)
最近做项目遇到这样一个问题输入框不允许有前后空格但字符中间可以有空格,怎么解决这个问题呢,接下来小编把ant Design-vue 解决input前后空格问题的实现代码分享给大家,感兴趣的朋友一起看看吧2022-10-10Vue CLI项目 axios模块前后端交互的使用(类似ajax提交)
这篇文章主要介绍了Vue-CLI项目-axios模块前后端交互的使用详解(类似ajax提交),本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-09-09
最新评论