过滤器vue.filters的使用方法实现


Posted in Javascript onSeptember 18, 2019

写项目的时候,有一些方法我们是需要全局使用的,比如数字的四色五入保留小数点啊、一些工具方法、字符的格式化啊等等。这些很多页面需要用的、使用频率极高的方法,我们一般会将其封装为全局的方法;我以前是这样做的,有这么几种方式:

1、挂载到vue.prototype

在main.js入口文件中挂载到vue.prototype,如我们封装一个获取时间戳的函数。

Vue.prototype.now = Date.now || function () { 
  return new Date().getTime(); 
};

然后就可以在.vue页面中使用了

<script> 
  export default {  
    mounted(){ 
      console.log('now:' + this.now()); 
    }, 
  } 
</script>

2、全局混入mixins

同样也还是在main.js中。

mixins的全局注入规则大家应该都懂,如果组件中没有这个getTime方法,那么就会在页面中注入这个方法。

Vue.mixin({
 data() {},
 methods: {
  getTime() { 
   return new Date().getTime();
  }
 } 
});
new App({
 el: '#app'
 // ...
});

3、关于vue.filters

(1)问题

前面两种方法弊端有很多,比如一般将全局变量挂载到prototype总是不太好的,状态管理我们用vuex;第二个全局混入的话,子组件中也会混入这些方法等等;最大的弊端就是代码的可读性和维护问题,如果项目体积大了,复用的方法多了,总不能都挂到prototye上去对吧?
这个时候,vue.filters过滤器就能够较好的解决这个问题。

(2)使用

先看一波官网-->传送门

ok,看完了,基本了解了过滤器的概念和基本使用方式以后,我们具体到项目中的使用。

新建一个filters文件夹,丢一行代码(很常用的一行代码,就是对数字做一些四舍五入的处理)

过滤器vue.filters的使用方法实现

数字四舍五入保留两位小数点

main.js中引入

// global filters
import Vue from 'vue';
import * as filters from '@/filters'; 

Object.keys(filters).forEach((key) => {
 Vue.filter(key, filters[key]);
});

然后页面中就可以使用了

<div>{{num | formatAmountFixed2}}</div>

<script>
data(){
  return {
    num: 11111
  }
}
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
模拟用户操作Input元素,不会触发相应事件
May 11 Javascript
js多级树形弹出一个小窗口层(非常好用)实例代码
Mar 19 Javascript
JS实现在线统计一个页面内鼠标点击次数的方法
Feb 28 Javascript
小巧强大的jquery layer弹窗弹层插件
Dec 06 Javascript
分享javascript实现的冒泡排序代码并优化
Jun 05 Javascript
js数组操作方法总结(必看篇)
Nov 22 Javascript
vue+ElementUI实现订单页动态添加产品数据效果实例代码
Jul 13 Javascript
npm 下载指定版本的组件方法
May 17 Javascript
快速搭建Node.js(Express)用户注册、登录以及授权的方法
May 09 Javascript
微信jssdk踩坑之签名错误invalid signature
May 19 Javascript
js实现菜单跳转效果
Dec 11 Javascript
javascript数组includes、reduce的基本使用
Jul 02 Javascript
layui问题之自动滚动二级iframe页面到指定位置的方法
Sep 18 #Javascript
解决使用layui对select append元素无效或者未及时更新的问题
Sep 18 #Javascript
Flutter实现仿微信底部菜单栏功能
Sep 18 #Javascript
详解element-ui中表单验证的三种方式
Sep 18 #Javascript
layui的布局和表格的渲染以及动态生成表格的方法
Sep 18 #Javascript
vue中使用element组件时事件想要传递其他参数的问题
Sep 18 #Javascript
解决layui追加或者动态修改的表单元素“没效果”的问题
Sep 18 #Javascript
You might like
codeigniter数据库操作函数汇总
2014/06/12 PHP
mysql desc(DESCRIBE)命令实例讲解
2016/09/24 PHP
PHP自定义多进制的方法
2016/11/03 PHP
Laravel 6.2 中添加了可调用容器对象的方法
2019/10/22 PHP
Aster vs KG BO3 第一场2.18
2021/03/10 DOTA
js apply/call/caller/callee/bind使用方法与区别分析
2009/10/28 Javascript
javascript 运算数的求值顺序
2011/08/23 Javascript
JavaScript之编码规范 推荐
2012/05/23 Javascript
根据身份证号自动输出相关信息(籍贯,出身日期,性别)
2013/11/15 Javascript
文本框只能选择数据到文本框禁止手动输入
2013/11/22 Javascript
AngularJS的表单使用详解
2015/06/17 Javascript
实例详解Nodejs 保存 payload 发送过来的文件
2016/01/14 NodeJs
Angular表单验证实例详解
2016/10/20 Javascript
jQueryeasyui 中如何使用datetimebox 取两个日期间相隔的天数
2017/06/13 jQuery
vue.js实现左边导航切换右边内容
2019/10/21 Javascript
jQuery三组基本动画与自定义动画操作实例总结
2020/05/09 jQuery
基于aotu.js实现微信自动添加通讯录中的联系人功能
2020/05/28 Javascript
Vuex的热更替如何实现
2020/06/05 Javascript
vue2.0 解决抽取公用js的问题
2020/07/31 Javascript
Python 模拟登陆的两种实现方法
2017/08/10 Python
Python实现识别手写数字 简易图片存储管理系统
2018/01/29 Python
python模式 工厂模式原理及实例详解
2020/02/11 Python
pyautogui自动化控制鼠标和键盘操作的步骤
2020/04/01 Python
Django调用支付宝接口代码实例详解
2020/04/04 Python
Python Spyder 调出缩进对齐线的操作
2021/02/26 Python
印度最好的在线药品订购网站:PharmEasy
2018/11/30 全球购物
俄罗斯药房连锁店:ASNA
2020/06/20 全球购物
社团成立邀请函
2014/01/08 职场文书
新颖的化妆品活动方案
2014/08/21 职场文书
领导班子四风表现材料
2014/08/23 职场文书
2015年禁毒宣传活动总结
2015/03/25 职场文书
反邪教警示教育活动总结
2015/05/09 职场文书
2015年社区党建工作汇报材料
2015/06/25 职场文书
团队合作精神学习心得体会
2016/01/19 职场文书
简历上的自我评价,该怎么写呢?
2019/06/13 职场文书
Python学习之包与模块详解
2022/03/19 Python