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 相关文章推荐
JQuery 获得绝对,相对位置的坐标方法
Feb 09 Javascript
javascript 多浏览器 事件大全
Mar 23 Javascript
JS烟花背景效果实现方法
Mar 03 Javascript
jquery实现的用户注册表单提示操作效果代码分享
Aug 28 Javascript
JS实现仿QQ效果的三级竖向菜单
Sep 25 Javascript
体验jQuery和AngularJS的不同点及AngularJS的迷人之处
Feb 02 Javascript
Augularjs-起步详解
Jul 08 Javascript
addEventListener()与removeEventListener()解析
Apr 20 Javascript
VUE 配置vue-devtools调试工具及安装方法
Sep 30 Javascript
Node.js系列之发起get/post请求(2)
Aug 30 Javascript
JS array数组检测方式解析
May 19 Javascript
微信小程序实现登录注册功能
Dec 29 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通过PHPExcel导入Excel表格到MySQL数据库的简单实例
2016/10/29 PHP
PHP的HTTP客户端Guzzle简单使用方法分析
2019/10/30 PHP
将CKfinder整合进CKEditor3.0的新方法
2010/01/10 Javascript
初窥JQuery(二)事件机制(2)
2010/12/06 Javascript
jQuery1.3.2 升级到jQuery1.4.4需要修改的地方
2011/01/06 Javascript
js获得地址栏?问号后参数的方法
2013/08/08 Javascript
jQuery之字体大小的设置方法
2014/02/27 Javascript
JavaScript中诡异的delete操作符
2015/03/12 Javascript
jquery实现界面无刷新加载登陆注册
2016/07/30 Javascript
jQuery Validate插件自定义验证规则的方法
2016/12/27 Javascript
使用yeoman构建angular应用的方法
2017/08/14 Javascript
vue中的event bus非父子组件通信解析
2017/10/27 Javascript
ActiveX控件的使用-js实现打印超市小票功能代码详解
2017/11/22 Javascript
微信小程序获取用户信息的两种方法wx.getUserInfo与open-data实例分析
2019/05/03 Javascript
node.js处理前端提交的GET请求
2019/08/30 Javascript
Vue 实现html中根据类型显示内容
2019/10/28 Javascript
Vuex中的Mutations的具体使用方法
2020/06/01 Javascript
Node.js 中如何收集和解析命令行参数
2021/01/08 Javascript
Python中的pprint折腾记
2015/01/21 Python
Ruby使用eventmachine为HTTP服务器添加文件下载功能
2016/04/20 Python
解决Python print 输出文本显示 gbk 编码错误问题
2018/07/13 Python
python cs架构实现简单文件传输
2020/03/20 Python
Python实现获取系统临时目录及临时文件的方法示例
2019/06/26 Python
python实现信号时域统计特征提取代码
2020/02/26 Python
如何在Win10系统使用Python3连接Hive
2020/10/15 Python
ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
2020/10/21 Python
css3学习之2D转换功能详解
2016/12/23 HTML / CSS
波兰灯具、照明和LED购物网站:Lampy.pl
2019/03/11 全球购物
中学生期中自我鉴定
2014/04/20 职场文书
政治学求职信
2014/06/03 职场文书
烈士陵园扫墓感想
2015/08/07 职场文书
家长对孩子的寒假评语
2015/10/09 职场文书
Python3 使用pip安装git并获取Yahoo金融数据的操作
2021/04/08 Python
详解RedisTemplate下Redis分布式锁引发的系列问题
2021/04/27 Redis
SQL Server作业失败:无法确定所有者是否有服务器访问权限的解决方法
2021/06/30 SQL Server
CSS SandBox应用场景及常见问题
2022/06/25 HTML / CSS