美文网首页
Vue中watch的用法

Vue中watch的用法

作者: owlcity | 来源:发表于2023-01-09 11:19 被阅读0次

1、在vue中watch用来监听数据的变化,一旦发生变化可以执行一些其他操作

2、watch就是当值第一次绑定的时候,是不会执行监听函数的,只有值发生改变才会执行。如果需要在第一次绑定的时候也执行函数,则需要用到immediate属性,比如当父组件向子组件动态传值时,子组件props首次获取到父组件传来的默认值时,也需要执行函数

3、handle方法:immediate表示在watch中首次绑定的时候,是否执行handler,值为true则表示在watch中声明的时候,就立即执行handler方法,值为false,则和一般使用watch一样,在数据发生变化时才执行

4、deep,当需要监听一个对象的变化时,普通的watch方法无法监听带对象内部属性的变化,只有data中的数据才能够监听到变化,此时需要deep属性进行深度监听,设置deep:true,当对象的属性较多是,每个属性的变化都会执行handler

5、可以只监听对象的其中一个属性值,如下

watch: {
    'person.name': {
        handler(newVal, oldVal) {
            console.log(newVal, oldVal)
        },
        deep: true,
        immediate: true
    }
}

6、watch中不要使用箭头函数,即不要用箭头函数来定义watcher函数,因为箭头函数中的this是指向当前作用域,对于箭头函数来说,箭头函数中的this指向的是定义时的对象而不是函数运行时所在的对象,即全局定义时的window对象

7、方式有

watch: { // 简单监听
    pageSize(newVal, oldVal) {
      console.log(newVal, oldVal) 
    },
    person: { // 对对象进行深度监听
      handler(nv) {
        console.log(nv)
      },
      immediate: true,
      deep: true
    },
    'person.name': { // 对对象的某一个属性进行深度监听
      handler(nv) {
        console.log(nv)
      },
      immediate: true,
      deep: true
    }
 
}

8、watch和computed的区别

  • 1、computed的get必须有返回值(return),而watchreturn可有可无

  • 2、computed支持缓存,只有依赖的数据发生改变,才会重新进行计算,而watch不支持缓存,数据发生改变,会直接触发相应的操作

  • 3、computed可以自定义名称,而watch只能监听和data里面名称相同的属性

  • 4、computed适用于复杂的运算,而watch适合一些消耗性功能,比如Ajax

  • 5、computed不支持异步,当computed内有异步操作是无效,无法监听数据的变化,而watch支持异步

  • 6、computed属性值会默认走缓存,计算属性是基于它们的响应式依赖进行缓存的,也就是基于data中声明过或者父组件传递的props中的数据通过计算得到的值,而watch监听的函数接受两个参数,第一个是最新的值,第二个是输入之前的值

  • 7、如果一个属性是由其他属性计算而来的,这个属性依赖其他属性,多对一或者一对一,一般用computed,当一个属性发生变化时,需要执行对应的操作,一对多,一般用watch

相关文章

  • Vue中的watch用法

    Vue中的watch用法 Vue.js中的watch主要用于观察Vue实例上的数据变动。 栗子:

  • vue watch用法

    vue watch用法

  • Vue中watch的详细用法

    在Vue中,使用watch来响应数据的变化。watch的用法大致有下面三种: 1. 基本用法 下面代码是watch...

  • Vue中watch的详细用法

    在vue中,使用watch来响应数据的变化。watch的用法大致有三种。下面代码是watch的一种简单的用法:''...

  • vue watch基础用法

    在vue中,使用watch来响应数据的变化。watch的用法大致有三种。下面代码是watch的一种简单的用法: 直...

  • watch - vue中watch 用法

    参考文档:https://www.cnblogs.com/yesu/p/9546458.html[https://...

  • Watch监听

    侦听器,监听数据的变化,基础用法在vue中,使用watch来响应数据的变化。watch的用法大致有三种。 1、下面...

  • VUE中watch用法

    一、 watch是什么? 监测 Vue 实例变化的一个表达式或方法。回调函数得到的参数为新值和旧值,用一个函数取代...

  • vue中watch的用法

    监听某个数据的变化 当它发生变化时 触发相应的回调函数

  • Vue watch监听原理篇

    学习watch原理之前需要了解更新原理 首先清楚在vue中watch有几种常见用法 初始化watch时 需要看一下...

网友评论

      本文标题:Vue中watch的用法

      本文链接:https://www.haomeiwen.com/subject/kfipcdtx.html