过滤器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 相关文章推荐
firefox下frameset取不到值的解决方法
Sep 06 Javascript
使用JavaScript的AngularJS库编写hello world的方法
Jun 23 Javascript
原生javascript实现自动更新的时间日期
Feb 12 Javascript
Angularjs 创建可复用组件实例代码
Oct 09 Javascript
javascript 日期相减-在线教程(附代码)
Aug 17 Javascript
详解Vue组件实现tips的总结
Nov 01 Javascript
vue-cli配置环境变量的方法
Jul 09 Javascript
jQuery实现移动端笔触canvas电子签名
May 21 jQuery
详解node.js 事件循环
Jul 22 Javascript
如何搭建一个完整的Vue3.0+ts的项目步骤
Oct 18 Javascript
详解ES6 扩展运算符的使用与注意事项
Nov 12 Javascript
vue使用require.context实现动态注册路由
Dec 25 Vue.js
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
一拳超人中怪人协会钦定! S级别最强四人!
2020/03/02 日漫
那些年一起学习的PHP(二)
2012/03/21 PHP
php集成套件服务器xampp安装使用教程(适合第一次玩PHP的新手)
2015/06/03 PHP
使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇
2010/05/07 Javascript
JSON 数据格式介绍
2012/01/13 Javascript
js multiple全选与取消全选实现代码
2012/12/04 Javascript
js修改table中Td的值(定义td的单击事件)
2013/01/10 Javascript
JavaScript的arguments对象应用示例
2014/09/15 Javascript
Javascript数组操作函数总结
2015/02/05 Javascript
JavaScript中调用函数的4种方式代码实例
2015/07/08 Javascript
AngularJs解决跨域问题案例详解(简单方法)
2016/05/19 Javascript
javascript 数组的正态分布排序的问题
2016/07/31 Javascript
JS常用算法实现代码
2016/11/14 Javascript
js实现图片左右滚动效果
2017/02/27 Javascript
vue使用Axios做ajax请求详解
2017/06/07 Javascript
vue.js自定义组件directives的实例代码
2018/11/09 Javascript
微信小程序云函数使用mysql数据库过程详解
2019/08/07 Javascript
[59:30]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.22
2019/09/05 DOTA
[02:22]完美世界DOTA2联赛PWL S3 集锦第一期
2020/12/15 DOTA
学习python的几条建议分享
2013/02/10 Python
python继承和抽象类的实现方法
2015/01/14 Python
python使用电子邮件模块smtplib的方法
2016/08/28 Python
python多进程和多线程究竟谁更快(详解)
2017/05/29 Python
python GUI库图形界面开发之PyQt5滑块条控件QSlider详细使用方法与实例
2020/02/28 Python
Window系统下Python如何安装OpenCV库
2020/03/05 Python
HTML5中Localstorage的使用教程
2015/07/09 HTML / CSS
欧洲最大的高尔夫零售商:American Golf
2019/09/02 全球购物
ORACLE十问
2015/04/20 面试题
竞聘副主任科员演讲稿
2014/01/11 职场文书
优秀党支部事迹材料
2014/01/14 职场文书
2014领导班子四风问题对照检查材料思想汇报
2014/09/21 职场文书
大学生赌博检讨书
2014/09/22 职场文书
列车乘务员工作不细心检讨书
2014/10/07 职场文书
校友回访母校寄语
2015/02/26 职场文书
教您:房贷工资收入证明应该怎么写?
2019/08/19 职场文书
七年级作文之冬景
2019/11/07 职场文书