首页 > 其他分享 >VUE watch监听器的基本使用方法详解

VUE watch监听器的基本使用方法详解

时间:2023-04-04 14:35:44浏览次数:48  
标签:VUE obj watch newVal oldVal handler 监听器 监听

1、下面代码是watch的一种简单的用法

  <div id="app">
      <input type="text" v-model="firstName" />
  </div>
   <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
   <script>
  var vm=new Vue({
      el:"#app",
      data:{
          firstName:"张"
      },
      watch:{         
          firstName:(newVal,oldVal){
  //firstName即为你想监听的数据的名称,要监听谁函数名就用谁的 如监听v-model的firstName                    
  //newVal:表示改变后的值,即第一个形参,不要调换位置
  //oldVal:表示改变前的值,
              console.log({newVal,oldVal});   //  {newVal: "陈", oldVal: "张"}
          }
          //直接写一个监听处理函数,当每次监听到cityName值发生改变时,执行函数。
          //也可以在所监听的数据后面直接加字符串形式的方法名:firstName: 'nameChange'
      },
      methods:{
          nameChange(){
           }
      }
  })
   vm.firstName = "陈";//改变监听的值
</script>

2、immediate 立即监听

  使用watch基本用法时有一个特点,就是当值第一次绑定的时候,不会执行监听函数,只有值发生改变才会执行。如果我们需要在最初绑定值的时候也执行函数,则就需要用到immediate属性。

  watch: {
    firstName: {
      handler(newName, oldName) {
        this.fullName = newName + ' ' + this.lastName;
      },
      { immediate: true }
    }
  }

  监听的数据后面写成对象形式,包含handler方法和immediate,上面简单的写法我们写的函数其实就是在写这个handler方法、默认省略而已。

3、handler方法

  <div id="app">
      <div>
          <p>Number: {{ myNumber }}</p>
          <p>Number: <input type="text" v-model.number="myNumber"></p>
      </div>
  </div>
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  <script>
  new Vue({
      el: '#app',
      data: {
          myNumber: 'Dawei'
      },
      watch: {
          myNumber: {
              handler(newVal, oldVal) {
                  console.log('newVal', newVal);
                  console.log('oldVal', oldVal);
              },
              //immediate为true时则立即触发回调函数;如果为false,则和上面的例子一样,不会立即执行回调。
              immediate: true
            }
        }
   })
  </script>
  //handler方法就是你watch中需要具体执行的方法

4、 deep属性

  对于对象或者对象中的属性,我们如何监听?那么就介绍deep属性。它的作用就是解决这个问题的关键。

  <div id="root">
      <p>obj.a: {{obj.a}}</p>
      <p>obj.a: <input type="text" v-model="obj.a"></p>
  </div> 
   <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
   <script>
      new Vue({
          el: '#root',
          data: {
              obj: {
                   a: 123
              }
          },
          watch: {
              obj: {
              handler(newName, oldName) {
                  console.log(newName, oldName);
              },
              immediate: true,
              deep:true
              }
          } 
  })
	</script>

  上面的代码如果不加deep:true 那么console中就不会执行,只执行第一次,输出结果为undefined
  默认情况下 handler 只监听obj这个属性它的引用的变化,我们只有给obj赋值的时候它才会监听到。
   这个时候就可以使用deep深入观察,监听器会一层层的往下遍历,给对象的所有属性都加上这个监听器,但是这样消耗过大。
总结
侦听器一般来说是用来监听数据的变化,默认是在数据发生变化时执行。
监听的数据名放到这里面作为函数名,这个函数里面有两个参数,一个是新值,一个是旧值。
在vue中,使用watch来响应数据的变化,关于watch的用法大致有三种。

作者:黄俊宇

标签:VUE,obj,watch,newVal,oldVal,handler,监听器,监听
From: https://www.cnblogs.com/DTCLOUD/p/17286303.html

相关文章

  • vue 常用动画
    来源: https://juejin.cn/post/6844903638402334734Vue常用transition动画效果记录我的代码果然有问题2018年07月15日13:48 ·  阅读3839先简单介绍下transition标签的使用方法主要用于v-show,v-if或router-view的进出场动画模板<transitionn......
  • vue第三课:简单点击器应用
    简单需求:1,最小为0,小于0则不能再点击减少,并显示提示2,最大值为10,小于10则可以点击增加,超过10则不能再点击,并显示提示<!DOCTYPEhtml><html><head><metacharset="UTF-8"><title>v-html测试</title><scriptsrc="vue.js"></script>......
  • vue第二课:常用标签
    1,v-text指令 <divid='app'><h2v-text="message+'???'"></h2><h2v-text="info"></h2><h2>{{message+'??'}}江苏</h2></div><script>Vue.co......
  • vue侦听器
    侦听data里的数据变化:方法格式:<script>  constvm=newVue({    el:"#app",    data:{      username:"张三",      userList:[        {"id":1,"name":"张三"},        {"i......
  • VSCode打开Vue项目
    打开VSCode                                                                       打开文件夹并选择vue的文件夹  ......
  • 4.15 vue中watch computed
    在Vue.js中,computed是一种计算属性,它能够根据依赖的数据动态计算出一个新的值。computed属性可以定义为一个函数,该函数返回需要计算的值。当它所依赖的数据发生变化时,Vue.js会自动重新计算这个值并将其更新到组件上。与computed对应的还有另外两种常见的属性,分别是meth......
  • vue下拉框联动 数据清空后,赋值无效
     1.问题描述:规格型号与设备类型联动,当选择“规格型号”后,清空“设备类型”选择框内容,选择数据赋值时失效。   2.解决 添加this.$forceUpdate();进行强制渲染,效果实现。 getSecondName(){   this.$forceUpdate();  }, ......
  • vue3+vite 解决本地调用时跨域请求
    1、config配置文件中,axios默认请求地址;改为"/api",否则还是请求环境变量中的地址; 2、vite.config.ts文件中做如下配置:  server:{  open:true,//启动项目自动弹出浏览器  port:8081,//启动端口  cors:true,  proxy:{   "/api":{  ......
  • vue做播放器和进度条
    <template><video-playerclass="video-playervjs-custom-skin"ref="videoPlayer":playsinline="true":options="playerOptions"@play="onPlayerPlay($event)"@pause="onP......
  • 【vue】vue3中的动画
    vue版本:vue3不过是控制动画放到了标签内控制在上图中,是绑定到了stylevue中关于动画的封装入场出场动画进入开始状态(时间点).v-enter-from{}动态效果(时间段).v-enter-active{}终止状态(时间点).v-enter-to{}.v-leave-from{}.v-leave-active{}.v-lea......