您的位置:首页 > 产品设计 > UI/UE

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