vue的过滤器和计算属性
2017-08-05 00:00
429 查看
1. 过滤器
Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化。
之前自带许多自带的过滤器:
{{msg | currency}}
{{msg | json}}
现在2.0把内置的过滤器全部删除了。
过滤器可以用在两个地方:mustache 插值和 v-bind 表达式(从 2.1.0 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示:
<!-- in mustaches -->
{{ message | capitalize }}
<!-- in v-bind -->
<div v-bind:id="rawId | formatId"></div>
过滤器函数总接受表达式的值作为第一个参数。
new Vue({
// 创建一个首字母大写的过滤器
filters: {
capitalize: function (value) {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
}
})
过滤器可以串联
{{ message | filterA | filterB }}
过滤器是 JavaScript 函数,因此可以接受参数:
{{ message | filterA('arg1', arg2) }}
字符串 'arg1' 将传给过滤器作为第二个参数, arg2 表达式的值将被求值然后传给过滤器作为第三个参数
为了在其他指令中实现更复杂的数据变换,你应该使用计算属性。
2. 计算属性
模板内的表达式是非常便利的,但是它们实际上只用于简单的运算。在模板中放入太多的逻辑会让模板过重且难以维护。例如:
<div id="example">
{{ message.split('').reverse().join('') }}
</div>
在这种情况下,模板不再简单和清晰。在意识到这是反向显示 message 之前,你不得不再次确认第二遍。当你想要在模板中多次反向显示 message 的时候,问题会变得更糟糕。
这就是对于任何复杂逻辑,你都应当使用计算属性的原因。
computed: {
// a computed getter
reversedMessage: function () {
// `this` points to the vm instance
return this.message.split('').reverse().join('')
}
}
Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化。
之前自带许多自带的过滤器:
{{msg | currency}}
{{msg | json}}
现在2.0把内置的过滤器全部删除了。
过滤器可以用在两个地方:mustache 插值和 v-bind 表达式(从 2.1.0 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示:
<!-- in mustaches -->
{{ message | capitalize }}
<!-- in v-bind -->
<div v-bind:id="rawId | formatId"></div>
过滤器函数总接受表达式的值作为第一个参数。
new Vue({
// 创建一个首字母大写的过滤器
filters: {
capitalize: function (value) {
if (!value) return ''
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
}
})
过滤器可以串联
{{ message | filterA | filterB }}
过滤器是 JavaScript 函数,因此可以接受参数:
{{ message | filterA('arg1', arg2) }}
字符串 'arg1' 将传给过滤器作为第二个参数, arg2 表达式的值将被求值然后传给过滤器作为第三个参数
为了在其他指令中实现更复杂的数据变换,你应该使用计算属性。
2. 计算属性
模板内的表达式是非常便利的,但是它们实际上只用于简单的运算。在模板中放入太多的逻辑会让模板过重且难以维护。例如:
<div id="example">
{{ message.split('').reverse().join('') }}
</div>
在这种情况下,模板不再简单和清晰。在意识到这是反向显示 message 之前,你不得不再次确认第二遍。当你想要在模板中多次反向显示 message 的时候,问题会变得更糟糕。
这就是对于任何复杂逻辑,你都应当使用计算属性的原因。
computed: {
// a computed getter
reversedMessage: function () {
// `this` points to the vm instance
return this.message.split('').reverse().join('')
}
}
相关文章推荐
- vue-cli 计算属性(对数据进行处理/类似过滤器)
- vue-计算属性
- Vue中计算属性computed的示例解读
- 解决vue 更改计算属性后select选中值不更改的问题
- Vue计算属性和监听属性
- vue计算属性
- vue 计算属性computed和观察watch 和方法methods
- Vue入门 - 计算属性与watchers
- Vue.js中计算属性和方法的区别
- 计算属性 vue
- vue-计算属性不能直接修改
- VUE计算属性
- vue-computed计算属性
- Vue之计算属性
- Vue.js的计算属性
- vue之计算属性
- vue2.0+基础知识连载(13)--- 计算属性的使用
- 【Vue.js】- 计算属性
- vue计算属性
- Vue--基础模板语法以及计算属性