Vue案例引起的「过滤器」的使用

最近在项目的开发中,出现一些格式化数据的状况,好比字母的大小写,好比一些价格的数据格式。等等一些格式的显示。bash

Name Price
BTC $3896.23
ETH $136.64

在上面的表格中,咱们须要处理数据的显示。这是咱们时常遇到的状况。微信

一般咱们会直接处理数据的输出,能够这么作。函数

computed: {
    result() {
      return this.prices.map(price => "$" + price);
    }
}
复制代码

这些都是经过修改数据作到的。优化

不过,Vue 中给咱们提供了一种格式化数据功能「过滤器」。ui

filters 与 计算属性(computed),方法(methods)不一样的是,filters 不会修改数据,只是改变用户看到的输出。Vue 从 2.0 版本以后去除了内置的「过滤器」。因此咱们在使用时须要本身去定义。this

接下来,咱们就来看看看在 Vue 中如何使用「过滤器」。spa

首先过滤器能够用在两个地方:差值表达式 {{ }} 和 v-bind 表达式,而后由管道操做符“ | ”进行指示。code

知道在什么地方时候,那咱们就再来看看如何定义过滤器。咱们有两种方式定义。开发

本地过滤器

咱们能够把过滤器定义在当前使用的组件内。咱们利用过滤器来修改上面的表格输出格式。string

{{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 的过滤器就说到这,你们不妨多多尝试下在项目中使用,提升咱们的开发效率,不能老是想着去修改数据,这些功能与套路有时会发挥很好的价值。

若是文章对你有启发,记得点个赞。

关注个人微信公众号:六小登登,更多干货文章,欢迎一块儿交流。

人人均可以成为高手。我是一个会技术,又写干货的码农。欢迎勾搭。

相关文章
相关标签/搜索