VIP用户交流群:462197261 收藏本站北冥有鱼 互联网前沿资源第一站 助力全行业互联网+
在线客服:78895949
tonglan
  • 当前位置:
  • 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中的用法

    广而告之:
    热门推荐:
    php 页面执行时间计算代码

    代码如下: 复制代码 代码如下:<? $pagestartime=microtime(); ?> <!--网页内容 start--> 网页内容 ... ... <!--网页内容 end--> <? $pageendtime = microtime(); $starttime = explode(" ",$pagestartime); $endtime = explode(" ",$pageendtime);···

    利用纯CSS3实现动态的自行车特效源码

    首先来看看实现的效果图(静态): 实例源码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>自行车</title> <style type="text/css"> * { margin: 0; padding: 0 } ···

    使用phonegap播放音频的实现方法

    实例如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Compass Example</title> <script type="text/javascript" charset="UTF-8" src=&···

    在Vue组件化中利用axios处理ajax请求的使用方法

    本文主要给大家介绍了关于在Vue组件化中利用axios处理ajax请求的使用方法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 推荐方式 首先在 main.js 中引入 axios // 引入 axios import axios from 'axios' 这时候如果你想在其它的组件中使用axios进行a···

    DedeCMS V5.5 Ajax评论调用会员头像的方法

     个人不喜欢DEDECMS原来自带的表情图标,所以才有替换成会员头像的想法。修改方法如下:   1。打开/plus/feedback_ajax.php 查找第206行和274行   以下为引用的内容: <span class='moodico'><img src='<?php echo $cfg_temp···

    菊花转动的jquery加载动画效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <link charset="utf-8" href="css/reset.css" rel="external nofollow" rel="stylesheet"> <link charset="utf-8" href="css/···

    PHP通过bypass disable functions执行系统命令的方法汇总

    一、为什么要bypass disable functions 为了安全起见,很多运维人员会禁用PHP的一些“危险”函数,例如eval、exec、system等,将其写在php.ini配置文件中,就是我们所说的disable functions了,特别是虚拟主机运营商,为了彻底隔离同服务器的客户,以及避免出现大面积的安全问题···

    关于IE标签LI文字换行问题

    折腾好久了,搜了一下还真有牛人解决了这个问题。在使用UL和LI显示文字的时候,由于IE浏览器对LI的文字长度没有默认强制令起一行。导致如果文字超出UL设定的宽度再先有的位置上折行,造成显示问题。 解决方法: 复制代码代码如下: ul li{ white-space:nowrap; } 看清···

    php实现基于pdo的事务处理方法示例

    本文实例讲述了php实现基于pdo的事务处理方法。分享给大家供大家参考,具体如下: 实例1: try {} catch () {} 形式 <?php $dsn = 'mysql:dbname=cheyun_cms;host=127.0.0.1'; $user = 'root'; $password = '111111'; //采用预处理+事务处理执行SQL操作 //1.连接数据···

    mysql备份脚本 mysqldump使用方法详解

    本文实例为大家分享了mysql备份脚本,供大家参考,具体内容如下 #!/bin/bash #全备方式,一般在从机上执行,适用于小中型mysql数据库 #删除15天以前备份 #作者:fafu_li #时间:2015.08.10 source /etc/profile #加载系统环境变量 source ~/.bash_profile #加载用户环境···