vue Watch和Computed的使用总结

 更新时间:2021年05月20日 14:35:40   作者:Ruovan  
本文主要介绍Vue.js中监听器和计算属性的相关知识点,包括对普通属性的监听、对对象的监听、对数组的监听,以及计算属性的Set方法,计算属性与监听器的区别等等

01. 监听器watch

(1)作用

  • watch:用于监听data中的数据变化,只在被监听的属性值发生变化时执行
export default {
    data() {
        return {
            number: 1
        }
    },
    watch:{
        // 普通监听方法,这里表示监听data中的 number属性
        // 第一个参数表示改变后的新值,第二个参数表示改变前的旧值
        number(newVal,oldVal){
            console.log(newVal);
            console.log(oldVal);
        }
    }
}

(2)属性和方法

  • immediate:表示在组件创建后,立即监听属性,在最初绑定值的时候,设置为:immediate: true
  • handler:监听对象的时候使用,发生变化时,执行handler中的方法~
  • deep:表示深度监听对象、数组内部的属性的变化,设置为:deep: true
export default {
    data(){
        return {
            number: 1
        }
    },
    watch: {
        // 监听 number属性
        number: {
			handler(newVal, oldVal){
                
            },
            immediate: true, // 立即监听
        }
    }
}

(3)监听对象

  • 可以监听对象的直接赋值操作
    • 但不能监听对象属性的添加、修改、删除
export default {
    data() {
        return {
            obj: {
                a: 1
            }
        }
    },
    watch: {
        obj: {
            handler(newVal){
                console.log('监听到了', newVal)
            },
            immediate: true
        }
    },
    created(){
        // 无法监听到,因为是对属性进行的修改操作
        // 打印一次,且打印结果为修改后的值,
        this.obj.a = 2 

        // 可以监听到,因为是直接对 对象进行的 赋值操作
        // 打印两次(immediate立即监听会打印一次,修改时打印一次)
        this.obj = { a: 2} 
    }
}

由于 Vue 会在初始化实例时,会对属性执行 getter/setter 转化过程

所以属性必须在 data 对象上存在,才能让 Vue 转换它,这样才能让它是响应式的

因此,Vue 无法检测到对象属性的添加、删除、修改等操作

默认情况下 handler 只监听对象内部属性的引用的变化

因此,我们只有进行赋值操作的时候,它才会监听到

  • 可以直接监听对象的某一个属性值
    • 如果这个属性是基本类型的值,就可以正常监听
export default {
    watch: {
        'obj.a': {
            handler(newVal){
                console.log(newVal)
            }
        }
    },
    created(){
        // 以下两个都可以监听到 打印两次
        this.obj.a = 2
        this.obj = { a:2 }
    }
}
  • 可以使用deep属性进行深度监听
    • 只能监听原有属性的变化,不能监听新增属性
    • vue 无法监听 this.$set 修改原有属性的变化

这是因为,this.$set()就是相当于在data中对初始值进行改变

它可以触发监听,但变化体现不出来,即newVal === oldVal

export default {
    watch: {
        obj: {
            handler(newVal){
            	console.log(newVal)
            },
            deep: true,
            immediate: true
        }
    },
    created(){
        // 进行深度监听后,直接修改属性的变化也可以监听到
        // 打印两次(因为immediate)
        this.obj.a = 2
        
        // 无法监听到 对象属性的增加
        // 打印一次,且打印结果为添加了新增属性的对象
        // 即,它只会 因immediate而执行一次 ,且打印输出 {a:1,b:2}
        this.obj.b = 2
        
        // 可以触发监听,但无法监听到变化
        // 打印两次,两次值都是{a:2},不能体现变化
        this.$set(this.obj, 'a', 2)
    }
}

(4)监听数组

  • 可以监听
    • 数组的直接赋值操作
    • 通过数组方法的添加、修改、删除操作
    • 通过this.$set()方法进行的数组操作

数组方法如pop()、push()等,和this.$set(arr, index, newVal)方法

它们可以触发监听,但无法体现变化,即newVal === oldVal

  • 无法监听
    • 无法监听数组的非数组方法的添加、删除、修改操作
    • 无法监听直接通过索引值改变数组的变化
    • 无法监听直接修改数组长度的变化
export default {
    data() {
        return {
            arr: [1]
        }
    },
    watch: {
        arr: {
            handler(newVal, oldVal) {
                console.log('新:', newVal)
                console.log('旧:', oldVal)
            },
            immediate: true
        }
    },
    created() {
        // 可以监听到---直接整个数组赋值
        this.arr = [2]
        
        // 无法监听到---索引赋值、长度修改
        this.arr[1] = 2
        this.arr[0] = 2
        this.arr.length = 2
        
        // 可以触发监听,但无法监听到变化 => 即新、旧值都是一样的
        this.arr.push(2)
        this.$set(this.arr, 0, 2)
    }
}

02. 计算属性computed

(1)计算属性的set方法

  • 计算属性可以写为一个 Object,而非 Function,只是 Function 形式是我们默认使用它的 get 方法,当写为 Object 时,我们还可以使用它的 set 方法
computed: {
  fullName: {
    get () {
      return `${this.firstName} ${this.lastName}`;
    },
    set (val) {
      const names = val.split(' ');
      this.firstName = names[0];
      this.lastName = names[names.length - 1];
    }
  }
}

当执行 this.fullName = 'Aresn Liang',computed 的 set 就会调用,firstName 和 lastName 就会被赋值为 Aresn 和 Liang

computed 可以依赖其它 computed,甚至是其它组件的 data

(2)区别

  • 计算属性和监听器
    • 计算属性computed是:监听依赖值的变化
      • 只要依赖值不变,都会直接读取缓存进行复用
      • 计算属性不能响应异步操作中数据的变化
      • 需要人为调用
    • 监听器watch是:监听属性值的变化
      • 只要属性值发生变化,都可以触发一个回调函数
      • 监听器可以响应异步操作中数据的变化
      • 自动触发
  • 计算属性和方法
    • methods 是一个方法,它可以接受参数,而 computed 不能
    • computed 是可以缓存的,methods 不会

(3)使用场景

  • 当一个属性受多个属性影响的时候就需要用到computed
  • 当一条数据影响多条数据的时候就需要用watch,如搜索数据

以上就是vue Watch和Computed的使用总结的详细内容,更多关于vue Watch和Computed的使用的资料请关注脚本之家其它相关文章!

相关文章

  • vuex页面刷新导致数据丢失的解决方案

    vuex页面刷新导致数据丢失的解决方案

    这篇文章主要介绍了vuex页面刷新导致数据丢失的解决方案,帮助大家更好的使用vue框架,感兴趣的朋友可以了解下
    2020-12-12
  • uniapp和vue组件之间的传值(父子传值,兄弟传值,跨级传值,vuex)

    uniapp和vue组件之间的传值(父子传值,兄弟传值,跨级传值,vuex)

    这篇文章主要介绍了uniapp和vue组件之间的传值(父子传值,兄弟传值,跨级传值,vuex),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • vue.js中for循环如何实现异步方法同步执行

    vue.js中for循环如何实现异步方法同步执行

    这篇文章主要介绍了vue.js中for循环如何实现异步方法同步执行问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • Vue常用传值方式、父传子、子传父及非父子实例分析

    Vue常用传值方式、父传子、子传父及非父子实例分析

    这篇文章主要介绍了Vue常用传值方式、父传子、子传父及非父子,结合实例形式分析了vue.js常见的传值方式及相关操作注意事项,需要的朋友可以参考下
    2020-02-02
  • Vue项目中使用flow做类型检测的方法

    Vue项目中使用flow做类型检测的方法

    这篇文章主要介绍了Vue项目中使用flow做类型检测的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • 浅谈Vue SSR 的 Cookies 问题

    浅谈Vue SSR 的 Cookies 问题

    本篇文章主要介绍了浅谈Vue SSR 的 Cookies 问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • vue.js实现日历插件使用方法详解

    vue.js实现日历插件使用方法详解

    这篇文章主要为大家详细介绍了vue.js模拟日历插件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • vue项目使用定时器每隔几秒运行一次某方法代码实例

    vue项目使用定时器每隔几秒运行一次某方法代码实例

    有时候在项目中我们经常需要设置简单的倒计时功能,这个可以通过定时器来实现,下面这篇文章主要给大家介绍了关于vue项目使用定时器每隔几秒运行一次某方法的相关资料,需要的朋友可以参考下
    2023-04-04
  • vue.js实现请求数据的方法示例

    vue.js实现请求数据的方法示例

    这篇文章主要给大家介绍了vue.js实现请求数据的方法示例,文中分别介绍了vue1.0和vue2.0的示例方法,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • 解决vue项目跳转同样的页面不刷新的问题思路详解

    解决vue项目跳转同样的页面不刷新的问题思路详解

    做公司官网项目的时候遇到的场景,顶部导航栏分类商品跳转到分类详情,然后在分类详情再次点击顶部导航栏里另外的分类商品,跳到同样的页面数据不刷新,下面小编给大家分享解决方式,关于vue跳转不刷新问题感兴趣的朋友一起看看吧
    2023-09-09

最新评论