前言
最近在项目的开发中,出现一些格式化数据的情况,比如字母的大小写,比如一些价格的数据格式。等等一些格式的显示。
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 的过滤器就说到这,大家不妨多多尝试下在项目中使用,提高我们的开发效率,不能总是想着去修改数据,这些功能与套路有时会发挥很好的价值。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小牛知识库的支持。
本文向大家介绍animate.css在vue项目中的使用教程,包括了animate.css在vue项目中的使用教程的使用技巧和注意事项,需要的朋友参考一下 在vue项目中使用动画其实有多种方式,可以使用vue中的过渡transition,可以使用animate动画与transition配合使用,也可以单独使用animate动画库(详情可见vue官网-过渡:过渡),下面我们开始介绍在vue中单独使用
1. 前言 本小节我们将学习如何使用过滤器。包括如何注册过滤器、过滤器的使用、过滤器的串联、过滤器的传参。过滤器的使用非常简单,同学们只需要多写几个例子就可以完全掌握。 2. 慕课解释 Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。 — 官方定义 过滤器是对即将显示的数据做进一步的筛选处理,然后进行显示,值得注意的是过滤器并没有改变原来的数据,只是在原数据的基础上产生新的数据。过
本文向大家介绍Android 使用SearchView过滤RecyclerView中的项目,包括了Android 使用SearchView过滤RecyclerView中的项目的使用技巧和注意事项,需要的朋友参考一下 示例 添加filter方法RecyclerView.Adapter: itemsCopy在适配器的构造函数中初始化。itemsCopy.addAll(items) 如果您这样做,只需f
本文向大家介绍使用vue手写一个过滤器相关面试题,主要包含被问及使用vue手写一个过滤器时的应答技巧和注意事项,需要的朋友参考一下 全局过滤器 Vue.filter('addHobby',(val,hobby)=>{ return val + hobby }) 局部过滤器 filters:{ addHobby(val,hobby){ return val + hobby } }
问题内容: 我的查询是这样的: 它会引发QueryParsingException [[comos_v2] [条件]过滤器不支持[mediaType]] ,而映射中不存在“ mediaType”字段。我的问题是为什么术语过滤器不引发异常? 问题答案: 以上不是有效的查询DSL。在上述条款过滤器中,“ mediaType”字段的值应为数组 应该是以下内容:
本文向大家介绍使用vue cli4.x搭建vue项目的过程详解,包括了使用vue cli4.x搭建vue项目的过程详解的使用技巧和注意事项,需要的朋友参考一下 cli-4.x已经发布好久了,斟酌了好久,还是决定将原来的cli-2.x升级到4.x,详细的升级过程可以戳这里 1、创建项目 vue create vuetest 2、选择配置方式 这里我选择的是手动配置(使用↑ ↓箭头切换,Enter