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 相关文章推荐
javascript ajax 仿百度分页函数
Oct 29 Javascript
textarea不能通过maxlength属性来限制字数的解决方法
Sep 01 Javascript
jquery中ajax使用error调试错误的方法
Feb 08 Javascript
jQuery插件slides实现无缝轮播图特效
Apr 17 Javascript
理解JavaScript的变量的入门教程
Jul 07 Javascript
Jqgrid之强大的表格插件应用
Dec 02 Javascript
JS+CSS实现鼠标经过弹出一个DIV框完整实例(带缓冲动画渐变效果)
Mar 25 Javascript
jqGrid 学习笔记整理——进阶篇(一 )
Apr 17 Javascript
js判断浏览器是否支持严格模式的方法
Oct 04 Javascript
详解jQuery lazyload 懒加载
Dec 19 Javascript
Bootstrap面板使用方法
Jan 16 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
Sep 30 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动态创建Web站点的方法
2011/08/14 PHP
php cURL和Rolling cURL并发方式比较
2013/10/30 PHP
phpMyAdmin自动登录和取消自动登录的配置方法
2014/05/12 PHP
PHP递归统计系统中代码行数
2019/09/19 PHP
ThinkPHP5 框架引入 Go AOP,PHP AOP编程项目详解
2020/05/12 PHP
javascript arguments 传递给函数的隐含参数
2009/08/21 Javascript
jquery实现的可隐藏重现的靠边悬浮层实例代码
2013/05/27 Javascript
把jquery 的dialog和ztree结合实现步骤
2013/08/02 Javascript
jquery中的on方法使用介绍
2013/12/29 Javascript
JQuery EasyUI 日期控件如何控制日期选择区间
2014/05/05 Javascript
函数window.open实现关闭所有的子窗口
2015/08/03 Javascript
jquery实现点击向下展开菜单项(伸缩导航)效果
2015/08/22 Javascript
jQuery checkbox选中问题之prop与attr注意点分析
2016/11/15 Javascript
详解Angular路由 ng-route和ui-router的区别
2017/05/22 Javascript
微信小程序对接七牛云存储的方法
2017/07/30 Javascript
mui框架移动开发初体验详解
2017/10/11 Javascript
webpack打包并将文件加载到指定的位置方法
2018/02/22 Javascript
深入理解Vue父子组件生命周期执行顺序及钩子函数
2018/08/12 Javascript
jQuery实现的简单歌词滚动功能示例
2019/01/07 jQuery
jquery实现二级导航下拉菜单效果实例
2019/05/14 jQuery
layui问题之自动滚动二级iframe页面到指定位置的方法
2019/09/18 Javascript
python2.7+selenium2实现淘宝滑块自动认证功能
2018/02/24 Python
python画折线图的程序
2018/07/26 Python
numpy下的flatten()函数用法详解
2019/05/27 Python
python3 打印输出字典中特定的某个key的方法示例
2019/07/06 Python
django Admin文档生成器使用详解
2019/07/22 Python
django-rest-swagger的优化使用方法
2019/08/29 Python
PyQt5结合matplotlib绘图的实现示例
2020/09/15 Python
pytorch下的unsqueeze和squeeze的用法说明
2021/02/06 Python
CSS3条纹背景制作的实战攻略
2016/05/31 HTML / CSS
巴西一家专门从事家居和装饰的连锁店:Camicado
2019/08/14 全球购物
高一自我鉴定
2013/12/17 职场文书
2015毕业生实习期工作总结
2015/04/09 职场文书
爱国主题班会教案
2015/08/14 职场文书
基于python的matplotlib制作双Y轴图
2021/04/20 Python
Elasticsearch 索引操作和增删改查
2022/04/19 Python