Vue.js实战学习—计算属性

Vue.js实战学习—计算属性

3.1 什么是计算属性
在模板中双向绑定一些数据或表达式时,如果表达式过长,或逻辑更为复杂时,就会变得臃肿甚至难以阅读和维护,比如:

<div>
    {{text.split(',').reverse().join(',')}}
</div>

上例可以用计算属性进行改写:

<div id="app">
    {{reversedText}}
</div>
<script>
    var app = new Vue({
        el:'#app',
        data: {
            text:'123,456'
        },
        computed:{
            reversedText:function (){
                return   this.text.split(',').reverse().join(',');
            } 
        }
    })
</script>

所有的计算属性都以函数的形式写在Vue实例内的computed的选项内,最终返回计算后的结果。

3.2 计算属性的用法
计算属性还可以依赖多个Vue实例的数据,只要其中一个数据变化,计算属性就会重新执行,视图也会更新。例如:

<div id="app">
    总价{{prices}}
</div>
<script>
    var app = new Vue({
        el:'#app',
        data: {
            package1:[
                {
                    name:'iphone 7',
                    peice:7199,
                    count:2
                },
                {
                    name:'ipad',
                    price:2888,
                    count:1
                }
            ],
            package2:[
                {
                    name:'apple',
                    price:3,
                    count:5
                },
                {
                    name:'banana',
                    price:2,
                    count:10
                }
            ]
        },
        computed:{
            prices:function (){
                var prices = 0;
                for(var i = 0;i < this.package1.length; i++){
                    prices += this.package1[i].price*this.package1[i].count;
                }
                for(var i = 0;i < this.package2.length; i++){
                    prices += this.package2[i].price*this.package2[i].count;
                }
                return prices;
            }
        }
    })
</script>

当package1或package2中的商品有任何变化,计算属性prices就会自动更新,视图中的总价也会自动变化。
每一个计算属性都包含一个getter和一个setter,我们上面的两个示例都是计算属性默认用法,只是利用了getter来读取。在你需要的时候也可以提供一个setter函数,当手动修改计算属性的值就像修改一个普通数据那样时,就会触发setter函数,执行一些自定义的操作,例如:

<div id="app">
    姓名:{{fullName}}
</div>
<script>
    var app = new Vue({
        el:'#app',
        data: {
           firstName:'Jack',
            lastName:'Green'
        },
        computed: {
            fullName:{
                //getter,用于读取
                get:function(){
                    return this.firstName + ' ' + this.lastName;
                },
                //setter,写入时触发
                set:function (newValue) {
                    var names = newValue.split(' ');
                    this.firstName = names[0];
                    this.lastName = names[names.length - 1];
                }
            }
        }
    })
</script>

当执行app.fullName = ‘John Doe’时,setter就会被调用,数据firstName和lastName就会相对更新,视图也同样会被更新。
绝大多数情况下,我们只会用默认的getter方法来读取一个计算属性,在业务中很少用到setter,所以在声明一个计算属性时,可以直接使用默认的写法,不必将getter和setter都声明。
计算属性除了上述简单的文本插值外,还经常用于动态地设置元素的样式名称class和内联样式style。当使用组件时,计算属性也经常用来动态传递props。
计算属性还有两个很实用的小技巧容易被忽略:一是计算属性可以依赖其他计算属性;二是计算属性不仅可以依赖当前Vue实例的数据,还可以依赖其他实例的数据。

3.3 计算属性缓存
调用methods里的方法也可以与计算属性起到同样的作呕用,比如:

<div id="app">
    {{reversedText()}}
</div>
<script>
    var app = new Vue({
        el:'#app',
        data: {
            text:'123,456'
        },
        methods:{
            reversedText:function (){
                return  this.text.split(',').reverse().join(',');
            }
        }
    })
</script>

计算属性是基于它的依赖缓存的。一个计算属性所依赖的数据发生变化时,它才会重新取值,所以只要text不改变,计算属性也不会更新。当methods则不同,只要重新渲染,它就会被调用,因此函数也会被执行。
使用计算属性还是methods取决于你是否需要缓存,当遍历大数组和做大量计算时,应当使用计算属性,除非你不希望得到缓存。

侦听器
虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过 watch 选项提供了一个更通用的方法,来响应数据的变化。当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的。

计算属性vs 侦听器
Vue 提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:侦听属性。当你有一些数据需要随着其它数据变动而变动时,你很容易滥用 watch——特别是如果你之前使用过 AngularJS。然而,通常更好的做法是使用计算属性而不是命令式的 watch 回调。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值