vue抽取公共方法———方法一
方法一:Vue插件
1.概述
作用:满足vue之外的需求,特定场景的需求
比如说,让你在每个单页面组件里,都可以调用某个方法(公共方法),或者共享某个变量等
2.使用方法
【声明插件】- 【写插件】-【注册插件】-【使用插件】
生命插肩和写插件是同时进行的,注册插件到Vue对象中,最后在Vue组件的时候使用写的插件
声明插件
插件的需求都是公共部分,所以会创建文件夹utils,里面创建一个js文件,基本内容如下:

install的第一个参数Vue表示Vue的实例,也就是Vue对象,第二个参数opt表示的是设置选项,是指在调用这个插件时可以传一个对象。
比如这个对象调用时接受一个参数no,在插件中,我需要将这个no赋值给Vue对象的另一个data,就可以这样
注册插件
注册插件其实就是用import引入后,然后通过Vue.use(插件名),就跟vue-router和vue-resource一样。
例如:我们通常在main.js中引入各种东西,并且组件的根实例也在这里。

通过import引入文件,然后在创建根组件之前,让Vue对象通过use方法注册插件,通过这两步,就可以使用插件了。
3.写插件、使用插件
按照官方文档,写插件有四种方法,示例如下:(链接:https://cn.vuejs.org/v2/guide/plugins.html#ad)

3.1【添加实例方法或属性】
1.核心思想是,通过prototype来添加方法和属性
2.写:

3.用:

4.假如添加的是属性:
如:Vue.prototype.no= 1;
会发生什么事情呢?
1.不管是【按值传递类型】还是【按引用传递类型】,该变量都不会被不同组件所共享,更准确的说,假如有A,B两个组件。A里面的no数值改变,B组件里的no数值是不会跟着改变的。
2. 当组件里没有该属性时,调用时,显示的是通过插件获取的值;
当组件里有该属性时,调用是,显示的是该组件里该属性的值;
所以,函数也是这样的,组件里的同名函数总是会覆盖插件提供的函数。
3.2【添加全局方法或属性】
1.核心思想:就是给Vue对象添加一个方法或属性。
和3.1区别是,3.1是给组件内部使用的,相当于组件Methods里定义的方法,而3.2是给Vue对象使用的。
例如:有一个方法test(),那么:
通过3.1添加,是在组件里,通过this.test()来调用
通过3.2添加,是在外面通过Vue实例,如Vue.test()来调用
2.写:
Vue.test= function (){ alert(2) }
3.用:
Vue.test()
3.3【注入组件】
1.核心思想:
就像写Vue组件时,那样写,方法名保持一致,其会在执行组件对应的方法名之前执行,或者不需要这种需求,只是简单注入到各个组件methods中
2.写:

【注入给非Vue实例本身就有的方法】:
假如是给比如methods属性的某个方法,例如上图的showBank,若组件中有showBank就不会执行插件中的这个showBank,如果组件中没有才会执行插件中的这个showBank。其实就是同名先执行组件本身中的方法。
3.用:
和正常写在组件内部methods属性里面的方法使用方式一样,注入其实就是和写在内部methods中等同!
3.4【添加全局资源】
和正常方法类似,甚至几乎一样,可以添加【自定义指令】【过滤器】【过渡】等,这里以【过滤器】为例
1.写:

:
2.用:
{{num | formatTime}}
4.demo示例

版权声明:参考自http://blog.csdn.net/qq20004604
vue抽取公共方法———方法一的更多相关文章
- vue 引用公共方法(例子:截取字符串固定字数,其余显示...)
1.写公共js 2.main.js引入公共js 3.在组件中用this.common.方法名 引用
- vue学习笔记:在vue项目里面使用引入公共方法
首先新建一个文件夹:commonFunction ,然后在里面建立 一个文件common.js 建立好之后,在main.js里面引入这个公共方法 最后是调用这个公共方法 测试一下,我在公共方法里面写了 ...
- vue中添加util公共方法&&ES6之import、export
vue中添加util公共方法&&ES6之import.export https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Re ...
- 头像文件上传 方法一:from表单 方法二:ajax
方法一:from表单 html 设置form表单,内包含头像预览div,内包含上传文件input 设置iframe用来调用函数传参路径 <!--表单提交成功后不跳转处理页面,而是将处理数据返回给 ...
- JS数组 二维数组 二维数组的表示 方法一: myarray[ ][ ];方法二:var Myarr = [[0 , 1 , 2 ],[1 , 2 , 3, ]]
二维数组 一维数组,我们看成一组盒子,每个盒子只能放一个内容. 一维数组的表示: myarray[ ] 二维数组,我们看成一组盒子,不过每个盒子里还可以放多个盒子. 二维数组的表示: myarray[ ...
- 3分钟教会你把封装的js公共方法挂载在vue实例原型上
第一步:首先在src文件夹里面创建一个通用js文件夹,然后在创建的文件夹里面创建一个js文件 第二步:const 一个方法,然后通过export暴露出来(在同一个页面可以写多个方法,和暴露多个方法,在 ...
- 千锋教育Vue组件--vue基础的方法
课程地址: https://ke.qq.com/course/251029#term_id=100295989 <!DOCTYPE html> <html> <head& ...
- J2EE项目开发中常用到的公共方法
在项目IDCM中涉及到多种工单,包括有:服务器|网络设备上下架工单.服务器|网络设备重启工单.服务器光纤网线更换工单.网络设备撤线布线工单.服务器|网络设备替换工单.服务器|网络设备RMA工单.通用原 ...
- web开发过程中经常用到的一些公共方法及操作
进化成为程序猿也有段岁月了,所谓的经验,广度还是依旧,只不过是对于某种功能有了多种实现方式的想法.每天依旧不厌其烦的敲打着代码,每一行代码的回车似乎都有一种似曾相识的感觉.于是乎:粘贴复制,再粘贴再复 ...
随机推荐
- Java中的字符串常量池和JVM运行时数据区的相关概念
什么是字符串常量池 JVM为了减少字符串对象的重复创建,其维护了一个特殊的内存,这段内存被成为字符串常量池或者字符串字面量池 工作原理 当代码中出现字面量形式创建字符串对象时,JVM首先会对这个字面量 ...
- 数组中出现一次的两个数(三个数)& 求最后一位bit为1
对于两个数,对于结果中,剩余bit1来异或区分. 下面的解法,非常精简: int lastBitOf1(int number) { ); } void getTwoUnique(vector<i ...
- BeautifulSoup的高级应用 之.parent .parents .next_sibling.previous_sibling.next_siblings.previous_siblings
继上一篇BeautifulSoup的高级应用,主要解说的是contents children descendants string strings stripped_strings.本篇主要解说.pa ...
- linux 下同步异步,堵塞非堵塞的一些想法
补充: 发现一个更好的解释样例:同步是一件事我们从头到尾尾随着完毕.异步是别人完毕我们仅仅看结果. 堵塞是完毕一件事的过程中可能会遇到一些情况让我们等待(挂起).非堵塞就是发生这些情况时我们跨过. 比 ...
- 安卓开发,adb shell 调试sqlite3数据库
安卓开发,adb shell 调试sqlite3数据库 在安卓中创建了sqlite3数据库,想要调试怎么办? 通过adb shell来进行查看. 第一步,将adb加入到系统变量中. 这样就可以在命令行 ...
- 智课雅思词汇---十、pend是什么意思
智课雅思词汇---十.pend是什么意思 一.总结 一句话总结:[词根含义]:悬挂,垂;称量;支付 词根:-pend-, -pens- [词根含义]:悬挂,垂;称量;支付 [词根来源]:来源于拉丁语动 ...
- CUDA学习笔记(三)
近期对CUDA的理解,是对库的利用. 1 nvcc.exe是CUDA C编译器. 2 cudart.dll是CUDA运行时API动态链接库. 3 在Sdk目录下,\lib有CUTIL.CUDPP等函数 ...
- ViewPager设置不能滚动
设置ViewPager不能滑动 1:设置当前选中的页面 public void setCurrentItem(int item) { mPopulatePending = false; setCurr ...
- c# 的类成员
1 字段和变量的区别 字段是在类中定义的数据成员 由访问修饰符+数据类型+字段名(public string name) 字段就像类的一个小数据库,用来存放和类相关的数据; 而变量是没有修饰符的(in ...
- ASP.NET 部分视图
ASP.NET MVC 里的部分视图,相当于 Web Form 里的 User Control.我们的页面往往会有许多重用的地方,可以进行封装重用. 使用部分视图有以下优点: 1. 可以简写代码. ...