Vue项目引发的「过滤器」使用教程


Posted in Javascript onMarch 12, 2019

前言

最近在项目的开发中,出现一些格式化数据的情况,比如字母的大小写,比如一些价格的数据格式。等等一些格式的显示。

Name Price
BTC $3896.23
ETH $136.64

在上面的表格中,我们需要处理数据的显示。这是我们时常遇到的情况。

通常我们会直接处理数据的输出,可以这么做。

computed: {
 result() {
 return this.prices.map(price => "$" + price);
 }
}

这些都是通过修改数据做到的。

不过,Vue 中给我们提供了一种格式化数据功能「过滤器」。

filters 与 计算属性(computed),方法(methods)不同的是,filters 不会修改数据,只是改变用户看到的输出。Vue 从 2.0 版本之后去除了内置的「过滤器」。所以我们在使用时需要自己去定义。

接下来,我们就来看看看在 Vue 中如何使用「过滤器」。

首先过滤器可以用在两个地方:差值表达式 {{ }} 和 v-bind 表达式,然后由管道操作符“ | ”进行指示。

知道在什么地方时候,那我们就再来看看如何定义过滤器。我们有两种方式定义。

本地过滤器

我们可以把过滤器定义在当前使用的组件内。我们利用过滤器来修改上面的表格输出格式。

{{price.price | currency}}

filters: {
 currency(value) {
  return "$" + value;
 }
}

全局过滤器

这里需要注意的是,使用全局过滤器时,必须要在 Vue 的实例之前。

Vue.filter("currency", function (value) {
 return "$" + value;
});


new Vue({
 //...
})

此时,我们就可以愉快的在组件中使用过滤器了。

用户体验是非常重要的一个环节,我们可以利用过滤器去优化。通常利用表格展示数据时,你无法保证每个字段的属性值都是存在且合理的。

这时就可以利用「过滤器」。把不合理的值显示为 “--”,这是最为常见的手段。

filters: {
 filterPrice(value) {
  return value ? value : "--";
 }
}

过滤器参数

过滤器会把表达式中的值始终当作函数的第一个参数。由于过滤器是一个函数,所以我们也可以额外的传入参数。

{{ data | filterPrice(arg1, arg2) }}

比如我们把上面的案例修改一下,我们不仅仅需要把美元格式化,我们还需要格式化人民币等等,很多种的符号,这时就可以利用传参的方式。

{{price.price | filterPrice('$')}}

filters: {
 filterPrice(price, prefix) {
  return prefix + price;
 }
}

除此之外,「过滤器」还可以进行串联使用。

{{ data | filterA | filterB }}

串联使用时,会把第一个产生的结果,作为参数传递给第二个过滤器使用,以此类推。

好了今天我们 Vue 的过滤器就说到这,大家不妨多多尝试下在项目中使用,提高我们的开发效率,不能总是想着去修改数据,这些功能与套路有时会发挥很好的价值。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
flash javascript之间的通讯方法小结
Dec 20 Javascript
jquery 事件执行检测代码
Dec 09 Javascript
JQuery 引发两次$(document.ready)事件
Jan 15 Javascript
JavaScript去掉数组中的重复元素
Jan 13 Javascript
jQuery实现点击文本框弹出热门标签的提示效果
Nov 17 Javascript
JS+CSS实现仿新浪微博搜索框的方法
Feb 24 Javascript
JavaScript的React Web库的理念剖析及基础上手指南
May 10 Javascript
利用js+css+html实现固定table的列头不动
Dec 08 Javascript
微信小程序 登陆流程详细介绍
Jan 17 Javascript
vue项目环境变量配置的实现方法
Oct 12 Javascript
js实现动态增加文件域表单功能
Oct 22 Javascript
帮你提高开发效率的JavaScript20个技巧
Jun 18 Javascript
通过JS运行机制的角度说说作用域
Mar 12 #Javascript
Jquery的autocomplete插件用法及参数讲解
Mar 12 #jQuery
如何使用pm2快速将项目部署到远程服务器
Mar 12 #Javascript
详解用Webpack与Babel配置ES6开发环境
Mar 12 #Javascript
详解微信小程序框架wepy踩坑记录(与vue对比)
Mar 12 #Javascript
javascript中数组的常用算法深入分析
Mar 12 #Javascript
详解javascript 变量提升(Hoisting)
Mar 12 #Javascript
You might like
不要轻信 PHP_SELF的安全问题
2009/09/05 PHP
PHP和Mysqlweb应用开发核心技术-第1部分 Php基础-2 php语言介绍
2011/07/03 PHP
ThinkPHP在新浪SAE平台的部署实例
2014/10/31 PHP
php访问数组最后一个元素的函数end()用法
2015/03/18 PHP
Jquery 获取表单text,areatext,radio,checkbox,select值的代码
2009/11/12 Javascript
再次分享18个非常棒的jQuery表格插件
2011/04/10 Javascript
js获取图片大小的函数代码
2011/09/20 Javascript
解决Extjs 4 Panel作为Window组件的子组件时出现双重边框问题
2013/01/11 Javascript
基于Javascript实现二级联动菜单效果
2016/03/04 Javascript
浅谈JavaScript 数据属性和访问器属性
2016/09/01 Javascript
jQuery自定义插件详解及实例代码
2016/12/29 Javascript
jQuery实现获取隐藏div高度的方法示例
2017/02/09 Javascript
JS实现两周内自动登录功能
2017/03/23 Javascript
jQuery异步提交表单实例
2017/05/30 jQuery
基于Vue.js实现tab滑块效果
2017/07/23 Javascript
JavaScript 自定义事件之我见
2017/09/25 Javascript
Vuex 进阶之模块化组织详解
2018/01/12 Javascript
Javascript中prototype与__proto__的关系详解
2018/03/11 Javascript
Bootstrap table 服务器端分页功能实现方法示例
2020/06/01 Javascript
React Ant Design树形表格的复杂增删改操作
2020/11/02 Javascript
Python 2.7.x 和 3.x 版本的重要区别小结
2014/11/28 Python
解决PyCharm不运行脚本,而是运行单元测试的问题
2019/01/17 Python
python中的itertools的使用详解
2020/01/13 Python
python3安装OCR识别库tesserocr过程图解
2020/04/02 Python
CSS3近阶段篇之酷炫的3D旋转透视
2016/04/28 HTML / CSS
浅析css3中matrix函数的使用
2016/06/06 HTML / CSS
阿迪达斯希腊官方网上商店:adidas希腊
2019/04/06 全球购物
回馈慈善的设计师太阳镜:DIFF eyewear
2019/10/17 全球购物
超市主管竞聘书
2015/09/15 职场文书
2016大学生社会实践单位评语
2015/12/01 职场文书
小学体育课教学反思
2016/02/16 职场文书
浅谈由position属性引申的css进阶讨论
2021/05/25 HTML / CSS
教你使用TensorFlow2识别验证码
2021/06/11 Python
Java网络编程之UDP实现原理解析
2021/09/04 Java/Android
教你使用VS Code的MySQL扩展管理数据库的方法
2022/01/22 MySQL
电频谱管理的原则是什么
2022/02/18 无线电