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 07 Javascript
jQuery load方法用法集锦
Dec 06 Javascript
js函数的延迟加载实现代码
Oct 11 Javascript
20条学习javascript的编程规范的建议
Nov 28 Javascript
jQuery+slidereveal实现的面板滑动侧边展出效果
Mar 14 Javascript
基于ajax实现文件上传并显示进度条
Aug 03 Javascript
利用浮层使select不可选的实现方法
Dec 03 Javascript
Node.js中process模块常用的属性和方法
Dec 13 Javascript
微信小程序 仿猫眼实现实例代码
Mar 14 Javascript
vue.js计算属性computed用法实例分析
Jul 06 Javascript
jQuery添加新内容的四个常用方法分析【append,prepend,after,before】
Mar 19 jQuery
在vue中利用v-html按分号将文本换行的例子
Nov 14 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中的Class的几点个人看法
2006/10/09 PHP
PHP编程最快明白(第一讲 软件环境和准备工作)
2010/10/25 PHP
php 把数字转换成汉字的代码
2015/07/21 PHP
Symfony2使用Doctrine进行数据库查询方法实例总结
2016/03/18 PHP
PHP实现执行外部程序的方法详解
2017/08/17 PHP
php获取微信基础接口凭证Access_token
2018/08/23 PHP
解决PHP curl或file_get_contents下载图片损坏或无法打开的问题
2019/10/11 PHP
php使用redis的有序集合zset实现延迟队列应用示例
2020/02/20 PHP
Javascript 读后台cookie代码
2008/09/15 Javascript
jQuery 注意事项 与原因分析
2009/04/24 Javascript
Jquery乱码的一次解决过程 图解教程
2010/02/20 Javascript
JS解析json数据并将json字符串转化为数组的实现方法
2012/12/25 Javascript
js 利用image对象实现图片的预加载提高访问速度
2013/03/29 Javascript
带左右箭头图片轮播的JS代码
2013/12/18 Javascript
javascript事件冒泡详解和捕获、阻止方法
2014/04/12 Javascript
推荐一个自己用的封装好的javascript插件
2015/01/29 Javascript
jquery动态改变div宽度和高度
2015/02/09 Javascript
JavaScript如何自定义trim方法
2015/07/28 Javascript
无需 Flash 使用 jQuery 复制文字到剪贴板
2016/04/26 Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(二)
2017/01/21 Javascript
NodeJs模拟登陆正方教务
2017/04/28 NodeJs
vue.js与后台数据交互的实例讲解
2018/08/08 Javascript
ES6 系列之 Generator 的自动执行的方法示例
2018/10/19 Javascript
vue el-tree 默认展开第一个节点的实现代码
2020/05/15 Javascript
解决Python一行输出不显示的问题
2018/12/03 Python
Python实现队列的方法示例小结【数组,链表】
2020/02/22 Python
Sandro Paris美国官网:典雅别致的法国时尚服饰品牌
2017/12/26 全球购物
Supersmart英国:欧洲市场首批食品补充剂供应商之一
2018/05/05 全球购物
怎样写好自荐信和推荐信
2013/12/26 职场文书
安全施工标语
2014/06/07 职场文书
初中英语教师个人工作总结2015
2015/07/21 职场文书
运动会闭幕式致辞
2015/07/29 职场文书
详细了解MVC+proxy
2021/07/09 Java/Android
Redis中有序集合的内部实现方式的详细介绍
2022/03/16 Redis
Python采集股票数据并制作可视化柱状图
2022/04/04 Python
CentOS安装Nginx并部署vue
2022/04/12 Servers