Vue中使用watch监听的handler,immediate,deep属性

Vue中使用watch监听的handler,immediate,deep属性

new Vue({
  el: '#app',
  data: {
    num: 0,
    sum:10,
  },
  watch: {
    // 只要num的值发生变化,sum的值就会变化  不用handler的简洁写法
    num(newValue, oldValue) {
      this.sum= newValue;
    }
    // 也可以使用handler方法写
    num:{
        handler(newValue, oldValue) {
            this.sum = newValue;
        }
    }
  } 
})

1.handler方法和immediate/deep属性

1.1.immediate属性

watch的特点就是,刚挂载的时候是不执行的,只有挂载完成后的变化才会执行。如果我们想要初次挂载的时候就执行,就需要用上immediate属性(immediate:true)

new Vue({
  el: '#app',
  data: {
    num: 0,
    sum:10,
  },
  watch: {
    // 只要num的值发生变化,sum的值就会变化
    num:{
        handler(newName, oldName) {
          this.sum= newName;
        },
        immediate: true,
    }
  } 
})

1.2.handler方法

这里可以看出添加了一个handler方法,其实watch的语法中是一直有这个handler方法的,只是没有添加immediate和deep属性的时候可以省略。

也可以把方法提炼到methods里面去

new Vue({
  el: '#app',
  data: {
    num: 0,
    sum:10,
  },
  watch: {
    // 只要num的值发生变化,sum的值就会变化
    num:{
        handler: function (newName, oldName) {
          this.sum= newName;
        },
        immediate: true,
    }
  } 
})
new Vue({
  el: '#app',
  data: {
    num: 0,
    sum:10,
  },
  methods:{
    numfun (newName, oldName) {
       this.sum= newName;
    }
  },
  watch: {
    // 只要num的值发生变化,sum的值就会变化
    num:{
        handler: 'numfun',//这里引用的是methods里面定义的方法名
        immediate: true,
    }
  } 
})

当watcher监听到变化的时候,可以同时调用多个方法

new Vue({
  el: '#app',
  data: {
    msg: {
       name: 'aaa',
       age: 12
    },    num: 0,
    sum: 10
  },
  methods:{
    numfun (newName, oldName) {
       this.sum= newName;
    },
   logLine () {
      console.log('----logLine ---')
   },
   logContent () {
      console.log('----logContent ---')
   }
  },
  watch: {
    // 只要num的值发生变化,sum的值就会变化
    msg:{
        handler: 'numfun',//这里引用的是methods里面定义的方法名
        immediate: true,
    },
   'msg.name': [ 'logLine ' , 'logContent ' ]//数组的方式可以调用多个方法
  } 
})

1.3.deep属性

当我们想监听一个对象中的某个属性的时候,比方说上面msg对象中的name属性。由于Vue会在初始化实例时对属性执行getter/setter转化过程,所以属性必须在data对象上存在才能让Vue转换它,这样才能让它是响应的。

默认情况下,handler只会监听对象的引用变化,我们只有给对象重新赋值的时候,它才会监听到。

那如何才能想听到对象的具体的一个属性了?这就是deep的作用。

new Vue({
  el: '#app',
  data: {
    num: 0,
    sum: 10,
    msg:{
        name:'aaa',        age: 12    }
  },
  watch: {
    // 只要num的值发生变化,sum的值就会变化
    num:{
        handler(newName, oldName) {
          this.sum= newName;
        },
        immediate: true,
    },
    msg:{
        handler(newValue){
            console.log('msg的name发生了变化')
        },
        deep: true, // 默认是false
    }
  } 
})

deep的意思就是深入观察,监听器会一层层的往下遍历,给对象(msg)的所有属性都加上这个监听器,但是这样性能开销会非常大,任何修改对象里面的任何一个属性都会触发这个监听

器里面的handler。

2.字符串形式的监听

如果我们只想监听对象(msg)的某个具体的属性的变化,不监听对象(msg)的其他属性,可以使用字符串形式的监听。

watch: {
    'msg.name':{
        handler(newValue){
            console.log('msg的name发生了变化')
        },
        immediate: true // 默认false
        //deep: true, // 默认是false
    }
}

这样Vue.js才会一层一层解析下去,知道遇到对象(msg)的属性(name)

3.watch监听路由器

watch: {
    '$route'(to,from){
      console.log(to);   //to表示去往的界面 变化后的路由
      console.log(from); //from表示来自于哪个界面  变化前的路由
    }
  }
 
 
// 或者直接监听路由的属性path
watch:{
      '$route.path':function(newVal,oldVal){
        //console.log(newVal+"---"+oldVal);
        if(newVal === '/login'){
          console.log('欢迎进入登录页面');
        } else if(newVal === '/register'){
          console.log('欢迎进入注册页面');
        }
      }
 }
posted @ 2024-08-13 16:13  GQMM  阅读(187)  评论(0编辑  收藏  举报