vue 插件的方法代码详解


Posted in Javascript onJune 06, 2019

在开发项目的时候,我们一般都用 vue-cli 来避免繁琐的 webpack 配置和 template 配置。但是官方 cli3 现在并不支持搭建 plugin 开发的项目。

还好,已经有大神(Kazupon)走在了我们前面,我们就用现成的 vue-cli-plugin-p11n 。

如果你没有安装 vue-cli,请先安装

npm i -g @vue/cli

首先,搭建项目

vue create [your plugin name] && cd [your plugin name]
vue add p11n

这样我们就有了一个初始化的插件开发环境。

install 方法

开发 vue 插件其实就是写一个 install 方法,然后把这个方法暴露出来给你的用户,他们就可以用 Vue.use(plugin) 载入插件了。

借用 vue 官方 API 上的解释: 如果插件是一个对象,必须提供 install 方法。如果插件是一个函数,它会被作为 install 方法。install 方法调用时,会将 Vue 作为参数传入。 该方法需要在调用 new Vue() 之前被调用。 当 install 方法被同一个插件多次调用,插件将只会被安装一次。

export const install = function (Vue, options) {
 // Vue 就是 vue 实例
 // options 就是 Vue.use(plugin,options) 传入的第二个参数 options
 // 1. 添加全局方法或属性
 Vue.myGlobalMethod = function () {
  // 逻辑...
 }
 // 2. 添加全局资源
 Vue.directive('my-directive', {
  bind (el, binding, vnode, oldVnode) {
   // 逻辑...
  }
  ...
 })
 // 3. 注入组件选项
 Vue.mixin({
  created: function () {
   // 逻辑...
  }
  ...
 })
 // 4. 添加实例方法
 Vue.prototype.$myMethod = function (methodOptions) {
  // 逻辑...
 }
}

发布插件

p11n 已经帮助我们部署好了大部分 package.json 配置,只需要自己填写好 name,author,license,repository,description,keywords 这几个选项就可以了。

# login npm
npm login
# patch version
npm version patch
# publish
npm publish --access public

我自己写了一个非常简单的插件 vue-chart ,可以作为参考。

总结

以上所述是小编给大家介绍的vue 插件的方法代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
学习ExtJS Panel常用方法
Oct 07 Javascript
基于jquery的DIV随滚动条滚动而滚动的代码
Jul 20 Javascript
javascript中的window.location.search方法简介
Sep 02 Javascript
基于JQuery的列表拖动排序实现代码
Oct 01 Javascript
通过js获取div的background-image属性
Oct 15 Javascript
深入理解javascript中defer的作用
Dec 11 Javascript
JS实现不规则TAB选项卡效果代码
Sep 16 Javascript
学习javascript面向对象 理解javascript对象
Jan 04 Javascript
Angular弹出模态框的两种方式
Oct 19 Javascript
详解小程序输入框闪烁及重影BUG解决方案
Aug 31 Javascript
ng-zorro-antd 入门初体验
Dec 03 Javascript
原生js拖拽实现图形伸缩效果
Feb 10 Javascript
jquery+ajax实现上传图片并显示上传进度功能【附php后台接收】
Jun 06 #jQuery
node.js的http.createServer过程深入解析
Jun 06 #Javascript
vue中keep-alive组件的入门使用教程
Jun 06 #Javascript
vue2配置scss的方法步骤
Jun 06 #Javascript
JavaScript中将值转换为字符串的五种方法总结
Jun 06 #Javascript
详解Vue 如何监听Array的变化
Jun 06 #Javascript
js常见遍历操作小结
Jun 06 #Javascript
You might like
[原创]PHP中通过ADODB库实现调用Access数据库之修正版本
2006/12/31 PHP
javascript 面向对象编程 聊聊对象的事
2009/09/17 Javascript
json 实例详细说明教程
2009/10/31 Javascript
javascript 去字符串空格终极版(支持utf8)
2009/11/14 Javascript
JS在IE和FireFox之间常用函数的区别小结
2010/03/12 Javascript
IE下使用cloneNode注意事项分享
2012/11/22 Javascript
jquery连缀语法如何实现
2012/11/29 Javascript
SOSO地图JS画出标注和中心点以html形式运行
2013/08/09 Javascript
Javascript玩转继承(一)
2014/05/08 Javascript
浅析Javascript中“==”与“===”的区别
2014/12/23 Javascript
轻量级的原生js日历插件calendar.js使用指南
2015/04/28 Javascript
浅谈使用MVC模式进行JavaScript程序开发
2015/11/10 Javascript
JavaScript定义数组的三种方法(new Array(),new Array('x','y')
2016/10/04 Javascript
浅谈jquery的html方法里包含特殊字符的处理
2016/11/30 Javascript
js实现自动图片轮播代码
2017/03/22 Javascript
详解webpack 多页面/入口支持&公共组件单独打包
2017/06/29 Javascript
VSCode配置react开发环境的步骤
2017/12/27 Javascript
js动态获取时间的方法分析
2019/08/02 Javascript
swiper实现异形轮播效果
2019/11/28 Javascript
Vue自定义组件的四种方式示例详解
2020/02/28 Javascript
js+for循环实现字符串自动转义的代码(把后面的字符替换前面的字符)
2020/12/24 Javascript
[00:52]黑暗之门更新 新英雄孽主驾临DOTA2
2016/08/24 DOTA
[41:17]完美世界DOTA2联赛PWL S3 access vs CPG 第二场 12.13
2020/12/17 DOTA
零基础写python爬虫之urllib2使用指南
2014/11/05 Python
Python中list列表的一些进阶使用方法介绍
2015/08/15 Python
Python输出由1,2,3,4组成的互不相同且无重复的三位数
2018/02/01 Python
在PYQT5中QscrollArea(滚动条)的使用方法
2019/06/14 Python
python 实现任务管理清单案例
2020/04/25 Python
pytorch掉坑记录:model.eval的作用说明
2020/06/23 Python
UGG美国官网:购买UGG雪地靴、拖鞋和鞋子
2017/12/31 全球购物
世界顶级户外运动品牌折扣网站:LeftLane Sports
2019/06/12 全球购物
介绍一下Python下range()函数的用法
2013/11/07 面试题
教师岗位聘任书范文
2014/03/29 职场文书
交通安全标语
2014/06/06 职场文书
委托收款证明
2015/06/23 职场文书
创业计划书之少年玩具店
2019/09/05 职场文书