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 相关文章推荐
IE8下jQuery改变png图片透明度时出现的黑边
Aug 30 Javascript
js获取及修改网页背景色和字体色的方法
Dec 29 Javascript
微信小程序  action-sheet详解及实例代码
Nov 09 Javascript
JS中Array数组学习总结
Jan 18 Javascript
jQuery实现一个简单的轮播图
Feb 19 Javascript
Vue获取DOM元素样式和样式更改示例
Mar 07 Javascript
基于JS代码实现简单易用的倒计时 x 天 x 时 x 分 x 秒效果
Jul 13 Javascript
vue-cli项目优化方法- 缩短首屏加载时间
Apr 01 Javascript
Vue路由守卫之路由独享守卫
Sep 25 Javascript
VUE 解决mode为history页面为空白的问题
Nov 01 Javascript
JS数组方法reverse()用法实例分析
Jan 18 Javascript
微信小程序点击滚动到指定位置的实现
May 22 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
基于magic_quotes_gpc与magic_quotes_runtime的区别与使用介绍
2013/04/22 PHP
基于php下载文件的详解
2013/06/02 PHP
php程序员应具有的7种能力小结
2014/11/27 PHP
php利用反射实现插件机制的方法
2015/03/14 PHP
PHP用mysql_insert_id()函数获得刚插入数据或当前发布文章的ID
2016/11/25 PHP
javascript中巧用“闭包”实现程序的暂停执行功能
2007/04/04 Javascript
javascript中运用闭包和自执行函数解决大量的全局变量问题
2010/12/30 Javascript
JS常见问题整理(持续更新)
2013/08/06 Javascript
JS 实现导航栏悬停效果
2013/09/23 Javascript
可选择和输入的下拉列表框示例
2013/11/05 Javascript
改变状态栏文字的js代码
2014/06/13 Javascript
node.js中的path.extname方法使用说明
2014/12/09 Javascript
javascript委托(Delegate)blur和focus用法实例分析
2015/05/26 Javascript
jQuery插件之Tocify动态节点目录菜单生成器附源码下载
2016/01/08 Javascript
KnockoutJS 3.X API 第四章之click绑定
2016/10/10 Javascript
JavaScript对象封装的简单实现方法(3种方法)
2017/01/03 Javascript
JavaScript登录验证基础教程
2017/11/01 Javascript
JavaScript实现音乐自动切换和轮播
2017/11/05 Javascript
使用veloticy-ui生成文字动画效果
2018/02/08 Javascript
angularjs 获取默认选中的单选按钮的value方法
2018/02/28 Javascript
详解在create-react-app使用less与antd按需加载
2018/12/06 Javascript
jquery+css3实现的经典弹出层效果示例
2020/05/16 jQuery
python使用xmlrpc实例讲解
2013/12/17 Python
python 基础教程之Map使用方法
2017/01/17 Python
使用11行Python代码盗取了室友的U盘内容
2018/10/23 Python
python 使用cx-freeze打包程序的实现
2020/03/14 Python
Python基于execjs运行js过程解析
2020/11/27 Python
CSS3的 fit-content实现水平居中
2017/09/07 HTML / CSS
do you have any Best Practice for testing
2016/06/04 面试题
工程师求职简历的自我评价分享
2013/10/10 职场文书
金属材料工程毕业生个人的自我评价
2013/11/28 职场文书
医院信息公开实施方案
2014/05/09 职场文书
乡镇综治宣传月活动总结
2014/07/02 职场文书
董事长开业致辞
2015/07/29 职场文书
感谢信
2019/04/11 职场文书
Redis全局ID生成器的实现
2022/06/05 Redis