Vue computed 和 watch

通俗来讲,既能用 computed 实现又可以用 watch 监听来实现的功能,推荐用 computed重点在于computed 的缓存功能

1. computed

用来声明式的描述一个值依赖了其它的值,当所依赖的值或者变量改变时,计算属性也会跟着改变;

注:计算属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算。

new Vue({
    el: '#id',
    template: `<div>
        <span>Name: {{name}}<span>
    </div>`,
    data: {
        firstName: 'Leo',
        lastName: 'Alan'
    },
    computed: {
        name () {
            return `${this.firstName} + ${this.lastName}`
        }
    }
})

2. watch

监听的是已经在 data 中定义的变量,当该变量变化时,会触发 watch 中的方法。

computed 的区别是,watch 更加适用于监听某一个值的变化并做对应的操作,比如请求后台接口等,而 computed 适用于计算已有的值并返回结果

new Vue({
    el: '#app',
    template: `<div>
        // ...
    </div>`,
    data: {
        firstName: 'Leo',
        lastName: 'Alan',
        obj1: {
            a: 0
        }
    },
    watch: {
        // 监听 firstName, 当 firstName 发生变化时就会执行该函数
        firstName () {
            // 执行需要的操作...
            // 注:初始化不会执行,只有当被监听的值(firstName)发生变化时才会执行
        },

        // 监听lastName
        lastName: {
            handler (newName, oldName) {
                // 执行需要的操作...
            },
            immediate: true // true: 初始化时就会先执行一遍该监听对应的操作    
        },

        obj1: {
            handler () {
                // 执行需要的操作...
            },
            deep: true // 该属性默认值为false. 
            // 当被监听的值是对象,只有deep为true时,对应属性的值(obj1.a)发生变化时才能触发监听事件,但是这样非常消耗性能
        },

        // 监听对象具体的属性, deep就不需要设置为true了
        'obj1.a': {
            handler () {
                // 执行需要的操作...
            }
        }
    }
})

注意:不要在 computedwatch 中修改被依赖(或被监听)的值,这样可能会导致无限循环。