Vue中过滤器怎么用
这篇文章主要为大家展示了“Vue中过滤器怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue中过滤器怎么用”这篇文章吧。
前言
最近在项目的开发中,出现一些格式化数据的情况,比如字母的大小写,比如一些价格的数据格式。等等一些格式的显示。
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 的过滤器就说到这,大家不妨多多尝试下在项目中使用,提高我们的开发效率,不能总是想着去修改数据,这些功能与套路有时会发挥很好的价值。
以上是“Vue中过滤器怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341