交流群:462197261站长百科站长论坛热门标签收藏本站北冥有鱼 互联网前沿资源第一站 助力全行业互联网+
点击这里给我发消息
  • 当前位置:
  • vue 插件的方法代码详解

    北冥有鱼 教程大全 2019-11-09 ,,,

    在开发项目的时候,我们一般都用 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 插件的方法代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对北冥有鱼网站的支持!
    如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

    您可能感兴趣的文章:

    • vue插件mescroll.js实现移动端上拉加载和下拉刷新
    • vue 右键菜单插件 简单、可扩展、样式自定义的右键菜单
    • 详解vscode中vue代码颜色插件
    • 详解如何在vue项目中使用lodop打印插件
    • Vue-cli@3.0 插件系统简析
    • Vue封装的可编辑表格插件方法
    • Vue.js图片预览插件使用详解
    • vue中引用swiper轮播插件的教程详解
    • vue插件开发之使用pdf.js实现手机端在线预览pdf文档的方法
    • 解决vue中使用swiper插件问题及swiper在vue中的用法

    广而告之:
    热门推荐:
    JavaScript 动态生成方法的例子

    复制代码 代码如下:function User(properties){ for(var i in properties){ //遍历该对象的所有属性,并保证其作用于正确 (function(which){ var p=i; which["get"+p]=function(){ //动态生成的方法 return properties[p]; //返回对象的属性值 }; which["set"+p]=functio···

    PHP基于双向链表与排序操作实现的会员排名功能示例

    本文实例讲述了PHP基于双向链表与排序操作实现的会员排名功能。分享给大家供大家参考,具体如下: 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和···

    C#实现HTTP协议迷你服务器(两种方法)

    本文以两种稍微有差别的方式用C#语言实现HTTP协议的服务器类,之所以写这些,也是为了自己能更深刻了解HTTP底层运作。 要完成高性能的Web服务功能,通常都是需要写入到服务,如IIS,Apache Tomcat,但是众所周知的Web服务器配置的复杂性,如果我们只是需要一些简单的功能···

    js注意img图片的onerror事件的分析

    经过分析,发现网页中存在类似如下的代码: <img src="pic.gif" onerror="javascript:this.src='/noPic.gif';" alt="pic" /> 分析:特别注意 onerror,当图片不存在时,将触发 onerror,而 onerror 中又为 img 指定一个 NoPic.gif 图片。也就是说图片存在则显示 p···

    解决jquery的ajax调取后端数据成功却渲染失败的问题

    获取后端数据后,进行前端的页面渲染,数据读到了,渲染却失败了,经过无数次排查,发现了问题: 主要问题就是id的唯一性 $("#id")一般可以获得相应的对象,但是如果此时页面有多个同样的id,jquery就不行了,肯定不能查找到相应的对象 综述来说,如果渲染不成功,首先考虑要绑···

    调用帝国商城订单号的方法

    <TABLE border=0 cellSpacing=0 cellPadding=0 width="100%"> [e:loop={"select outproduct,ddtime,haveprice,truename,alltotal,checked,ddno from phome_enewsshopdd where outproduct='1' order by ddtime desc limit 100",10,24,0}] <TR> <Td width=···

    php二维码生成以及下载实现

    本文实例为大家分享了php二维码生成以及下载的具体代码,供大家参考,具体内容如下 <?php //引入phpqrcode库文件 define('IN_ECS', true); require(dirname(__FILE__) . '/includes/init.php'); include('includes/phpqrcode.php'); // 二维码数据 $data = 'ht···

    HTML5之SVG 2D入门11—用户交互性(动画)介绍及应用

    交互性 SVG拥有良好的用户交互性,例如: 1. SVG能响应大部分的DOM2事件。 2. SVG能通过cursor良好的捕捉用户鼠标的移动。 3. 用户可以很方便的通过设置svg元素的zoomAndPan属性的值来实现缩放等效果。 4. 用户可以很方便的把动画和事件结合起来,完成一些复杂的效果。 通过给S···

    var_export与var_dump的不同

    问题发现 在跟踪yratings_get_targets的时候, error_log(var_export(yblog_mspconfiginit("ratings"),true)); 老是打印出yblog_mspconfiginit(“ratings”)的返回是NULL 导致我以为是无法建立和DB的连接,走错路了一天。 最后才发现,这是var_export和var_dump的区别···

    MySQL 替换某字段内部分内容的UPDATE语句

    要替换某一个字段中的部分内容,可以用update 语句: UPDATE 表名 SET 字段名= REPLACE( 替换前的字段值, '替换前关键字', '替换后关键字' ) WHERE 字段名 REGEXP "替换前的字段值"; 比如替换标题里面的产品价格就是用这个方法复制代码 代码如下: UPDATE dede_archives···