vue 3 中watch 和watchEffect 的新用法

2022-04-15 0 384
目录
  • 一、watch新用法
    • 1.1、watch使用语法
    • 1.2、watch监听多个属性值
    • 1.3、watch监听引用数据类型
  • 二、watchEffect
    • 三、watch与watchEffect区别和联系
      • 3.1、watch特点
      • 3.2、watch配置项
      • 3.3、watchEffect特点
      • 3.4、watch与watchEffect联系

    一、watch 新用法

    选项式API中,watch 使用

    watch:{
    
     mood(curVal,preVal){
    
      console.log('cur',curVal);//最新值
    
      console.log('pre',preVal);//修改之前的值
    
     }
    
    }

    1.1、watch 使用语法

    Composition API 中,使用 watch 时,必须先引入。

    使用语法为:

    import { watch } from "vue"
    
    watch(
    
     name ,
    
     ( curVal , preVal )=>{ //业务处理  },
    
     options
    
    )

    共有三个参数,分别为:

    • name :需要帧听的属性
    • (curVal,preVal)=>{ //业务处理 } 箭头函数,是监听到的最新值和本次修改之前的值,此处进行逻辑处理。
    • options :配置项,对监听器的配置,如:是否深度监听。

    页面刚进入的时候并不会执行,值发生改变的时候,才会打印出当前最新值和修改之前的值。

    示例1:监听一个数据

    import { ref , watch } from "vue"
    
    export default{
    
     setup(){
    
      const mood = ref("")
    
      //帧听器
    
      watch(mood,(curVal,preVal)=>{
    
       console.log('cur',curVal);
    
       console.log('pre',preVal);
    
      },{
    
       //配置项
    
      })
    
      return{
    
       mood
    
      }
    
     }
    
    }

    watch 也可以监听多个属性值,此时传入的数据变成数组形式,配置项保持不变。

    1.2、watch 监听多个属性值

    示例2:监听多个属性

    watch([mood,target],([curMood,curTarget],[preMood,preTarget])=>{
    
     console.log('curMood',curMood);
    
     console.log('preMood',preMood);
    
     console.log('curTarget',curTarget);
    
     console.log('preTarget',preTarget);
    
    },{
    
      //配置项
    
    }) 
    

    1.3、watch 监听引用数据类型

    watch 监听引用数据类型时,如果只监听其中某个属性时,

    使用语法如下:

    watch(()=>obj.name,(curValue,preValue)=>{
    
     //帧听引用数据类型的某个属性
    
    },{
    
     //配置项
    
    })

    第一个参数,回调函数返回的是需要帧听对象的属性。后边的参数与上边的一致。

    示例3:帧听对象某个属性

    <template>
    
     <div>
    
      {{obj}}
    
      <input type="text" v-model="obj.name">
    
     </div>
    
    </template>
    
    <script>
    
    import { ref , reactive , watch } from "vue"
    
    export default{
    
     setup(){
    
      const obj = reactive({ name:'qq',sex:'女' })
    
      watch(()=>obj.name,(cur,pre)=>{
    
       console.log('cur',cur);
    
      },{ })
    
      return{
    
       obj
    
      }
    
     }
    
    }
    
    </script>

    如果我们试着把属性去掉,直接监听整个对象,发现watch好像失效了。此时我们就需要引入 watchEffect

    二、watchEffect

    watchEffect 也是一个帧听器,是一个副作用函数。它会监听引用数据类型的所有属性,不需要具体到某个属性,一旦运行就会立即监听,组件卸载的时候会停止监听。

    示例4:监听对象

    <template>
    
      <div>
    
        {{obj}}
    
        <input type="text" v-model="obj.name">
    
        <input type="text" v-model="obj.sex">
    
      </div>
    
    </template>
    
    <script>
    
    import {   reactive  , watchEffect } from "vue"
    
    export default{
    
      setup(){
    
        let obj = reactive({ name:'qq',sex:'女'})
    
        watchEffect(() => {
    
          console.log('name',obj.name);
    
          console.log('sex' , obj.sex);
    
        })
    
        return{
    
          obj
    
        }
    
      }
    
    }
    
    </script>
    
     
    
    

    watchEffect 参数只有一个回调函数。此时刷新页面进入,watchEffect 就会打印结果。

    三、watch 与 watchEffect 区别和联系

    watch watchEffect 都是监听器,那么它们之间有什么关系呢?

    3.1、watch特点

    watch 监听函数可以添加配置项,也可以配置为空,配置项为空的情况下,

    watch的特点为:

    • 有惰性:运行的时候,不会立即执行。
    • 更加具体:需要添加监听的属性。
    • 可以访问属性之前的值:回调函数内会返回最新值和修改之前的值。
    • 可配置:可以添加配置项。

    3.2、watch 配置项

    watch 的配置项可以补充watch特点上的不足,可以配置的有:

    • immediate:配置watch属性是否立即执行,值为 true 时,一旦运行就会立即执行,值为false时,保持惰性。
    • deep:配置 watch 是否深度监听,值为 true 时,可以监听对象所有属性,值为 false 时保持更加具体特性,必须指定到具体的属性上。

    3.3、watchEffect 特点

    watchEffect 副作用函数它的特点分别为:

    • 非惰性:一旦运行就会立即执行。
    • 更加抽象:使用时不需要具体指定监听的谁,回调函数内直接使用就可以。相比watch比较难理解。
    • 不可访问之前的值:只能访问当前最新的值,访问不到修改之前的值。

    3.4、watch 与 watchEffect 联系

    watch 的前两个特点与 watchEffect 的两个特点刚好相反,watch 通过配置项可以修改成带有 watchEffect 特点。

    示例5watch 监听对象

    <template>
    
     <div>
    
      {{obj}}
    
      <input type="text" v-model="obj.name">
    
     </div>
    
    </template>
    
    <script>
    
    import { ref , reactive , watch } from "vue"
    
    export default{
    
     setup(){
    
      const obj = reactive({ name:'qq',sex:'女' })
    
      watch(()=>obj,(cur,pre)=>{
    
       console.log('cur',cur);
    
      },{ 
    
       immediate:true,
    
       deep:true
    
      })
    
      return{
    
       obj
    
      }
    
     }
    
    }
    
    </script>

    到此这篇关于 vue 3 中watch 和watchEffect 的新用法的文章就介绍到这了,更多相关 vue 3 中watch 和watchEffect 内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript vue 3 中watch 和watchEffect 的新用法 https://www.niceym.com/20613.html