如何构建一个Vue插件并生成npm包


Posted in Javascript onOctober 26, 2020

    vue的插件一般用来添加全局性的功能,具体可分为:

  1. 添加全局方法或者属性;
  2. 添加全局资源(指令、过滤器等);
  3. 通过全局 mixin 方法添加一些组件选项;
  4. 在 Vue.prototype 上 添加 Vue 实例方法;
  5. 创建一个库,提供自己的 API,同时提供上面提到的一个或多个功能;    

一般来说我们在项目中倾向于第五种方式,可以通过创建一个js文件包含我们需要添加的多种全局性功能,指令、过滤器、实例方法之类的。这样的一个插件的构建也不难,主要就是使用vue提供的install 方法,传入Vue构造器以及你所能用到的参数对象;添加对应的功能,export出去,在需要的地方引入并Vue.use()方法注册即可;具体使用参考vue官网插件部分——开发插件。

    这一次我的项目中需要添加‘反爬'功能,具体实现就是后端在检测到用户触发‘反爬'规则后返回指定错误码以及对应的验证页面,前端在全局请求中监测该错误码,在检测到错误码后通过插件加载验证页面让用户去验证,并将验证结果反馈给后端,在后端收到验证结果后移除验证页面。

     需求确定后,我们就知道这个插件需要做的事情就是创建一个vue组件实例=>加载后端返回的页面=>解析并执行其中的js文件=>注册验证成功的全局回调函数。具体操作如下:

const antiReptilian = {
 install(Vue, options) {
  Vue.$antirept = checkText => {
   if (!checkText) return;
   let wrapperTemp = Vue.extend({
    // 1、创建构造器,定义模板
    template:
     '<div id="antiReptWrapper" style="z-index:9999 !important;"></div>'
   });
   let antiObj = new wrapperTemp().$mount().$el; // 2、创建实例
   antiObj.innerHTML = checkText;
   initScripts(antiObj);//3、解析并顺序执行js
   let App = document.getElementById('app');
   let wrapper = document.getElementById('antiReptWrapper');
   if (wrapper) {
    return;
   }
   App.appendChild(antiObj); // 4、把创建的实例添加到App中
   window.checkSucceed = res => {
    // 5、验证通过后移除实例
    App.removeChild(antiObj);
    window.location.reload();
   };
  };
 }
};

    需要注意的是通过设置innerHTML 的方式加载验证页面会导致内部的js文件不执行;因此我们还必须将验证页面的的js文件提取出来再重新插入,并且还要保证内部多个js文件的执行顺序,具体代码如下:

//重新引入js文件
const initScripts = function(cont) {
 let oldScripts = cont.getElementsByTagName('script');
 let newScripts = [];
 for (let i = 0; i < oldScripts.length; i++) {//提取内部js文件
  let newScript = document.createElement('script');
  newScript.type = 'text/javascript';
  newScript.innerHTML = oldScripts[i].innerHTML;
  if (oldScripts[i].src) {
   newScript.src = oldScripts[i].src;
  }
  newScripts.push(newScript);
 }
 while (oldScripts.length !== 0) {
  cont.removeChild(oldScripts[0]);//移除之前的js文件
 }
 for (let i = 0; i < newScripts.length; i++) {
  if (i == 0) {
   cont.appendChild(newScripts[i]);
  } else {//保证每个js文件按照之前的顺序执行
   newScripts[i - 1].onload = newScripts[
    i - 1
   ].onreadystatechange = function(event) {
    cont.appendChild(newScripts[i]);
   };
  }
 }
};

    到此为止这个简单的插件功能就完成了,在需要的地方引入、注册并调用Vue.$antirept()方法传入要加载的页面即可;

    将写好的插件生成npm包的方法也简单,分为以下几步:

1、前往npm官网注册一个npm账号=>【npm官网】;

2、将写好的插件生成一个简单的npm包:

  • 创建一个空文件夹,名称即为你的npm包的名称,注意名称不要与现有的npm包重复;
  • 切到该文件夹下,输入‘npm init'命令生成一个package.json文件,内部信息自定义;
  • 将写好的插件js文件拷到该文件夹下,重命名为index.js;
  • 在根目录下创建README.md文件,添加关于包的介绍信息(非必需);

3、发布创建好的包:

1. 若第一次发布包,执行‘ npm adduser'命令,输入前面注册好的npm账号,密码和邮箱;
2. 若不是第一次发布包,执行‘ npm login'命令进行登录,同样输入npm账号,密码和邮箱;
3.  登录成功以后,在刚才的文件夹下,执行‘npm publish'命令,即可发布该npm包;
4.  若要更新之前的包,只需要更改版本号,再执行‘npm publish'命令即可;

    至此一个简单的vue插件就生成了一个npm包了,以后使用就不需要加载js文件,可以直接通过npm的方式引入了,其它的小伙伴也可以一起愉快的玩耍了==>全剧终。

以上就是如何构建一个Vue插件并生成npm包的详细内容,更多关于vue生成npm包的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
在ASP.NET中使用JavaScript脚本的方法
Nov 12 Javascript
js菜单点击显示或隐藏效果的简单实例
Jan 13 Javascript
jQuery中triggerHandler()方法用法实例
Jan 19 Javascript
javascript实现10个球随机运动、碰撞实例详解
Jul 08 Javascript
Ionic实现仿通讯录点击滑动及$ionicscrolldelegate使用分析
Jan 18 Javascript
jQuery Easyui实现左右布局
Jan 26 Javascript
JavaScript 2048 游戏实例代码(简单易懂)
Mar 25 Javascript
深入理解Node.js 事件循环和回调函数
Nov 02 Javascript
javascript实现的图片预览功能
Mar 25 Javascript
详解vue-router 2.0 常用基础知识点之router-link
May 10 Javascript
利用adb shell和node.js实现抖音自动抢红包功能(推荐)
Feb 22 Javascript
关于vue-router的那些事儿
May 23 Javascript
解决vscode进行vue格式化,会自动补分号和双引号的问题
Oct 26 #Javascript
vue实现前端列表多条件筛选
Oct 26 #Javascript
vue实现单一筛选、删除筛选条件
Oct 26 #Javascript
vue通过接口直接下载java生成好的Excel表格案例
Oct 26 #Javascript
基于elementUI竖向表格、和并列的案例
Oct 26 #Javascript
原生js实现贪吃蛇游戏
Oct 26 #Javascript
JavaScript实现五子棋小游戏
Oct 26 #Javascript
You might like
php中的boolean(布尔)类型详解
2013/10/28 PHP
PHP 实现类似js中alert() 提示框
2015/03/18 PHP
php利用fsockopen GET/POST提交表单及上传文件
2017/05/22 PHP
Ucren Virtual Desktop V2.0
2006/11/07 Javascript
js控制iframe的高度/宽度让其自适应内容
2014/04/09 Javascript
js实现接收表单的值并将值拼在表单action后面的方法
2015/11/23 Javascript
jquery.cookie.js用法实例详解
2015/12/25 Javascript
Jquery uploadify上传插件使用详解
2016/01/13 Javascript
javascript获取select标签选中的值
2016/06/04 Javascript
JavaScript代码实现图片循环滚动效果
2020/03/19 Javascript
详解weex默认webpack.config.js改造
2018/01/08 Javascript
浅谈ajax在jquery中的请求和servlet中的响应
2018/01/22 jQuery
Javascript实现运算符重载详解
2018/04/07 Javascript
JavaScript实现简单轮播图效果
2018/12/01 Javascript
小程序瀑布流组件实现翻页与图片懒加载
2020/05/19 Javascript
javascript实现点击按钮切换轮播图功能
2020/09/23 Javascript
javascript局部自定义鼠标右键菜单
2020/12/08 Javascript
[01:03:27]NAVI vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python中使用glob和rmtree删除目录子目录及所有文件的例子
2014/11/21 Python
使用Python将Mysql的查询数据导出到文件的方法
2019/02/25 Python
Python 读取 YUV(NV12) 视频文件实例
2019/12/09 Python
使用python 的matplotlib 画轨道实例
2020/01/19 Python
TensorFlow的reshape操作 tf.reshape的实现
2020/04/19 Python
python中format函数如何使用
2020/06/22 Python
利用Python实现朋友圈中的九宫格图片效果
2020/09/03 Python
python爬虫用request库处理cookie的实例讲解
2021/02/20 Python
联想西班牙官网:Lenovo西班牙
2018/08/28 全球购物
上海中网科技笔试题
2012/02/19 面试题
路政管理专业个人自荐信范文
2013/11/30 职场文书
暑期实习鉴定
2013/12/16 职场文书
安全在我心中演讲稿
2014/09/01 职场文书
财务助理岗位职责范本
2014/10/09 职场文书
入党介绍人意见范文
2015/06/01 职场文书
Java网络编程之UDP实现原理解析
2021/09/04 Java/Android
vue3使用vuedraggable实现拖拽功能
2022/04/06 Vue.js
使用pd.merge表连接出现多余行的问题解决
2022/06/16 Python