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 相关文章推荐
解决3.01版的jquery.form.js中文乱码问题的解决方法
Mar 08 Javascript
ASP.NET MVC中EasyUI的datagrid跨域调用实现代码
Mar 14 Javascript
Bootstrap学习系列之使用 Bootstrap Typeahead 组件实现百度下拉效果
Jul 07 Javascript
如何使用bootstrap框架 bootstrap入门必看!
Apr 13 Javascript
JS实现禁止用户使用Ctrl+鼠标滚轮缩放网页的方法
Apr 28 Javascript
ExtJs异步无法向外传值和赋值的完美解决办法
Jun 14 Javascript
vue router 源码概览案例分析
Oct 09 Javascript
vue.js仿hover效果的实现方法示例
Jan 28 Javascript
babel7.x和webpack4.x配置vue项目的方法步骤
May 12 Javascript
layui表格内容溢出的解决方法
Sep 06 Javascript
react-intl实现React国际化多语言的方法
Sep 27 Javascript
分享一个vue实现的记事本功能案例
Apr 11 Vue.js
通过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 UTF8 文件的签名问题
2009/10/30 PHP
php cache类代码(php数据缓存类)
2010/04/15 PHP
php实现字符串首字母转换成大写的方法
2015/03/17 PHP
ThinkPHP开发框架函数详解:C方法
2015/08/14 PHP
CI框架常用方法小结
2016/05/17 PHP
理解JavaScript变量作用域更轻松
2009/10/25 Javascript
避免 showModalDialog 弹出新窗体的原因分析
2010/05/31 Javascript
用js模拟JQuery的show与hide动画函数代码
2010/09/20 Javascript
Javascript this 的一些学习总结
2012/08/02 Javascript
js获取事件源及触发该事件的对象
2013/10/24 Javascript
jquery解析JSON数据示例代码
2014/03/17 Javascript
JS实现根据当前文字选择返回被选中的文字
2014/05/21 Javascript
JavaScript中document对象使用详解
2015/01/06 Javascript
js+css实现的圆角边框TAB选项卡滑动门代码分享(2款)
2015/08/26 Javascript
js判断手机访问或者PC的几个例子(常用于手机跳转)
2015/12/15 Javascript
easyui关于validatebox实现多重规则验证的方法(必看)
2017/04/12 Javascript
从零开始学习Node.js系列教程四:多页面实现数学运算的client端和server端示例
2017/04/13 Javascript
PHP 实现一种多文件上传的方法
2017/09/20 Javascript
vuejs选中当前样式active的实例
2018/08/22 Javascript
详解如何在微信小程序开发中正确的使用vant ui组件
2018/09/13 Javascript
JavaScript"模拟事件"的注意要点详解
2019/02/13 Javascript
jQuery实现日历效果
2020/09/11 jQuery
详解JavaScript中的链式调用
2020/11/27 Javascript
python中的闭包函数
2018/02/09 Python
pytorch 加载(.pth)格式的模型实例
2019/08/20 Python
Python 装饰器原理、定义与用法详解
2019/12/07 Python
Python matplotlib模块及柱状图用法解析
2020/08/10 Python
python实现逻辑回归的示例
2020/10/09 Python
Python pickle模块常用方法代码实例
2020/10/10 Python
解决pytorch 数据类型报错的问题
2021/03/03 Python
Regatta官网:英国最受欢迎的户外服装和鞋类品牌
2019/05/01 全球购物
给校长的建议书
2014/03/12 职场文书
赔偿协议书范本
2014/09/12 职场文书
快递员岗位职责
2014/09/12 职场文书
城管执法人员纪律作风整顿思想汇报
2014/09/13 职场文书
南京导游词
2015/02/03 职场文书