过滤器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 相关文章推荐
JQuery 绑定事件时传递参数的实现方法
Oct 13 Javascript
js实现仿百度瀑布流的方法
Feb 05 Javascript
JS设置网页图片vspace和hspace属性的方法
Apr 01 Javascript
js+canvas简单绘制圆圈的方法
Jan 28 Javascript
bootstrap布局中input输入框右侧图标点击功能
May 16 Javascript
功能强大的Bootstrap使用手册(一)
Aug 02 Javascript
Jquery组件easyUi实现手风琴(折叠面板)示例
Aug 23 Javascript
JS匹配日期和时间的正则表达式示例
May 12 Javascript
vue 系列——vue2-webpack2框架搭建踩坑之路
Dec 22 Javascript
基于vue-cli vue-router搭建底部导航栏移动前端项目
Feb 28 Javascript
javascript 构建模块化开发过程解析
Sep 11 Javascript
Vue ElementUI实现:限制输入框只能输入正整数的问题
Jul 31 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
解决file_get_contents无法请求https连接的方法
2013/12/17 PHP
PHP弹出提示框并跳转到新页面即重定向到新页面
2014/01/24 PHP
浅析PHP关键词替换的类(避免重复替换,保留与还原原始链接)
2015/09/22 PHP
Yii2创建表单(ActiveForm)方法详解
2016/07/23 PHP
laravel 实现划分admin和home 模块分组
2019/10/15 PHP
javascript 写的一个简单的timer
2009/07/30 Javascript
web基于浏览器的本地存储方法应用
2012/11/27 Javascript
Jquery操作js数组及对象示例代码
2014/05/11 Javascript
JS实现CheckBox复选框全选全不选功能
2015/05/06 Javascript
JavaScript中使用concat()方法拼接字符串的教程
2015/06/06 Javascript
基于Jquery插件Uploadify实现实时显示进度条上传图片
2020/03/26 Javascript
AngularJS bootstrap启动详解及实例代码
2016/09/14 Javascript
javascript实现数据双向绑定的三种方式小结
2017/03/09 Javascript
jQuery查找dom的几种方法效率详解
2017/05/17 jQuery
node.js中express-session配置项详解
2017/05/31 Javascript
AngularJS监听ng-repeat渲染完成的两种方法
2018/01/16 Javascript
Vue 实现列表动态添加和删除的两种方法小结
2018/09/07 Javascript
JavaScript图片旋转效果实现方法详解
2020/06/28 Javascript
vue移动端写的拖拽功能示例代码
2020/09/09 Javascript
在vant 中使用cell组件 定义图标该图片和位置操作
2020/11/02 Javascript
[01:24:09]Ti4 冒泡赛第二轮DK vs C9 1
2014/07/14 DOTA
[01:05:56]2018DOTA2亚洲邀请赛3月29日 小组赛A组 Newbee VS VG
2018/03/30 DOTA
基于python的汉字转GBK码实现代码
2012/02/19 Python
Python自定义一个类实现字典dict功能的方法
2019/01/19 Python
django如何通过类视图使用装饰器
2019/07/24 Python
python实现输入的数据在地图上生成热力图效果
2019/12/06 Python
tensorflow生成多个tfrecord文件实例
2020/02/17 Python
python编程进阶之类和对象用法实例分析
2020/02/21 Python
PyInstaller的安装和使用的详细步骤
2020/06/02 Python
Python如何操作docker redis过程解析
2020/08/10 Python
Python基于staticmethod装饰器标示静态方法
2020/10/17 Python
pip 20.3 新版本发布!即将抛弃 Python 2.x(推荐)
2020/12/16 Python
应届生自我鉴定
2013/12/11 职场文书
细节决定成败演讲稿
2014/05/12 职场文书
2014小学数学教师个人工作总结
2014/12/18 职场文书
使用php的mail()函数实现发送邮件功能
2021/06/03 PHP