Vue.use源码解析
什么是Vue插件
关于什么是Vue插件大家可以去看官网的解释 ,总得来说就是提供一个全局注册/调用的能力。
怎样用
我们以Weex为例。
首先有一个toast.js
const Toast = {}Toast.install = (Vue, options) => { Vue.prototype.$toast = (msg, duration = 0.8) => { const modal = weex.requireModule('modal') modal.toast({ message: msg, duration: 0.8 }) }}Vue.use(Toast)
前台全栈学习交流圈:866109386,面向1-3经验年前台开发人员,帮助突破技术瓶颈,提升思维能力,群内有大量PDF可供自取,更有干货实战项目视频进群免费领取。
很简单,就是定义了一个Toast对面,而后给Toast对象创立一个install方法,方法里给Vue的prototype创立了一个$toast方法,该方法就是调用modal去弹一个toast,最后使用Vue.use方法去注册这个Toast插件。
而后我们还有一个index.vue:
<template> <div> <div class="box" @click="onclick" @longpress="onlongpress" @appear="onappear" @disappear="ondisappear"></div> </div></template> <script> const modal = weex.requireModule('modal') export default { methods: { onclick (event) { this.$toast("aaa", 0.8) }, onlongpress (event) { console.log('onlongpress:', event) modal.toast({ message: 'onlongpress', duration: 0.8 }) }, onappear (event) { console.log('onappear:', event) modal.toast({ message: 'onappear', duration: 0.8 }) }, ondisappear (event) { console.log('ondisappear:', event) modal.toast({ message: 'ondisappear', duration: 0.8 }) } } }</script> <style scoped>.box { border-width: 2px; border-style: solid; border-color: #BBB; width: 250px; height: 250px; margin-top: 250px; margin-left: 250px; background-color: #EEE;}</style>
前台全栈学习交流圈:866109386,面向1-3经验年前台开发人员,帮助突破技术瓶颈,提升思维能力,群内有大量PDF可供自取,更有干货实战项目视频进群免费领取。
在其中调用了this.$toast去使用插件的方法。
由此我们可以知道,Vue的插件机制就是通过Vue.use方法去注册的。
源码分析
Vue.use = function (plugin) { if (plugin.installed) { return } var args = toArray(arguments, 1); args.unshift(this); if (typeof plugin.install === 'function') { plugin.install.apply(plugin, args); } else if (typeof plugin === 'function') { plugin.apply(null, args); } plugin.installed = true; return this}; function toArray (list, start) { start = start || 0; var i = list.length - start; var ret = new Array(i); while (i--) { ret[i] = list[i + start]; } return ret}
use方法非常简单:
0x01:判断该插件能否已经注册,假如已经注册就直接return,防止重复注册。
0x02:而后通过toArray方法将Arguments这个类数组转换成真正的数据,并且去掉第一个元素。
0x03:将this,也就是Vue实例增加到toArray生成的args数组中。
0x04:判断use的入参plugin是install能否是一个方法,假如是则直接调用该方法。
0x05:假如第四步是false,则判断plugun本身是不是一个方法,假如是方法,则用它本身代替install去执行。
0x06:将plugin的installed标记位设置为true。
就这么简单的6步,use方法就分析完了,其实就是为了去执行插件的install方法,而结合上面的例子我们知道,install中就把$toast赋值给了Vue的prototype,在其余地方即可以使用的。
结合实际场景
学习了Vue的插件机制,那么这个机制我们能用来做什么呢?我们结合Weex来看。
首先我们知道,Weex是把bundle下发到用户端并渲染,所以一个页面的加载时间取决于两部分:bundle下载时间,bundle渲染时间。在不考虑本地缓存的情况下,bundle的大小直接决定了它的下载时间,以及客户所消耗的流量,所以我们需要有一种方式去尽可能的减小这个bundle的体积。这里Vue的插件机制即可以排上用场了。
首先我们把一部分共用,不太会改动的基础的代码放在用户端,这样bundle里的内容就应该是纯业务相关的代码,在把bundle下载下来之后手动将用户端的基础js拼接到bundle上,这样就能有效地减小bundle的体积,而想要使用这种方式,就必需把基础js通过Vue的插件机制注册,业务js中全局调用,不然是无法拼接的(除非你的基础js不通过webpack打包),毕竟webpack打包之后所有的代码都是封闭的,无法互相调用。
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » Vue.use源码解析