过滤器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 相关文章推荐
用正则xmlHttp实现的偷(转)
Jan 22 Javascript
简单的无缝滚动程序-仅几行代码
May 08 Javascript
一个CSS+jQuery实现的放大缩小动画效果
Feb 19 Javascript
JS实现鼠标单击与双击事件共存
Mar 08 Javascript
10分钟学会写Jquery插件实例教程
Sep 06 Javascript
一个JavaScript函数把URL参数解析成Json对象
Sep 24 Javascript
JavaScript操作class和style样式代码详解
Feb 13 Javascript
AngularJS中$watch和$timeout的使用示例
Sep 20 Javascript
详解vue2.0 不同屏幕适配及px与rem转换问题
Feb 23 Javascript
详解iview的checkbox多选框全选时校验问题
Jun 10 Javascript
JavaScript React如何修改默认端口号方法详解
Jul 28 Javascript
Vue中避免滥用this去读取data中数据
Mar 02 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
php自动加载的两种实现方法
2010/06/21 PHP
PHP+swoole+linux实现系统监控和性能优化操作示例
2019/04/15 PHP
Laravel6.0.4中将添加计划任务事件的方法步骤
2019/10/15 PHP
客户端 使用XML DOM加载json数据的方法
2010/09/28 Javascript
利用JQuery的load函数动态加载其它页面的内容的实现代码
2010/12/14 Javascript
30个最好的jQuery 灯箱插件分享
2011/04/25 Javascript
jquery随机展示头像代码
2011/12/21 Javascript
JavaScript中读取和保存文件实例
2014/05/08 Javascript
jquery向上向下取整适合分页查询
2014/09/06 Javascript
js简单实现Select互换数据的方法
2015/08/17 Javascript
分享我对JS插件开发的一些感想和心得
2016/02/04 Javascript
Adapter适配器模式在JavaScript设计模式编程中的运用分析
2016/05/18 Javascript
深入理解JavaScript单体内置对象
2016/06/06 Javascript
Javascript 动态改变imput type属性
2016/11/01 Javascript
bootstrap模态框垂直居中效果
2016/12/03 Javascript
微信小程序 登录的简单实现
2017/04/19 Javascript
vue2里面ref的具体使用方法
2017/10/27 Javascript
jQuery进阶实践之利用最优雅的方式如何写ajax请求
2017/12/20 jQuery
nodejs express配置自签名https服务器的方法
2018/05/22 NodeJs
vue axios数据请求get、post方法及实例详解
2018/09/11 Javascript
JavaScript 高性能数组去重的方法
2018/09/20 Javascript
jquery实现自定义树形表格的方法【自定义树形结构table】
2019/07/12 jQuery
如何使用jQuery操作Cookies方法解析
2020/09/08 jQuery
使用Python生成url短链接的方法
2015/05/04 Python
Python Paramiko模块的安装与使用详解
2016/11/18 Python
Python拆分大型CSV文件代码实例
2019/10/07 Python
PIL包中Image模块的convert()函数的具体使用
2020/02/26 Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
2020/06/12 Python
Python使用itcaht库实现微信自动收发消息功能
2020/07/13 Python
浅析关于Keras的安装(pycharm)和初步理解
2020/10/23 Python
职业女性的职业规划
2014/03/04 职场文书
户外活动总结
2015/02/04 职场文书
数学教师求职信范文
2015/03/20 职场文书
英语投诉信范文
2015/07/03 职场文书
《兰兰过桥》教学反思
2016/02/20 职场文书
导游词之河北野三坡
2019/12/11 职场文书