Vue插件可以是一个包含install方法的Object对象,此时插件被调用时会调用install方法,如下所示:
分宜网站建设公司创新互联,分宜网站设计制作,有大型网站制作公司丰富经验。已为分宜上千提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的分宜做网站的公司定做!
export default {
// 接收两个参数
// app: 应用上下文的实例
// options:插件输入的选项
install: (app, options) => {
console.log('app', app);
console.log('options', options);
// 做一些处理
// ……
}
}
Vue插件也可以是一个function函数,此时插件被调用时会调用function函数本身,如下所示:
export default function TestPlugin(app, options) {
console.log('app', app);
console.log('options', options);
}
上述已经阐述了如何编写自己的插件,插件编写完了之后就需要使用这些插件了,那这些插件应该如何使用呢?其实用起来很简单,应用上下文的实例上提供了对应的use方法。
app.use(plugin, [options]); // 返回一个应用实例,所以其可以链式添加新的插件
为什么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;
};
上述代码读起来很简单,其实现了以下几件事情:
网页标题:Vue3.0插件执行原理与实战
新闻来源:http://www.gawzjz.com/qtweb/news25/174725.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联