vue3中watch和watchEffect怎么使用

技术vue3中watch和watchEffect怎么使用这篇文章主要讲解了“vue3中watch和watchEffect怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学

本文主要讲解“如何在vue3中使用watch和watchEffect”。本文的解释简单明了,易学易懂。现在,请跟随边肖的思路,一起学习和学习“如何在vue3中使用watch和watchEffect”!

一、watch 新用法

选项式API中,watch 使用

watch:{

情绪(曲线,普雷瓦尔){ 0

console.log('cur ',curVal);//最新值

console.log('pre ',普雷瓦尔);//修改上一个值

}

}

1.1、watch 使用语法

在Composition API中,必须先介绍手表。

使用语法为:

从“vue”导入{ watch }

手表(

名字,

(curVal,普雷瓦尔)={//业务处理},

选择

)共有三个参数,分别为:

名称:需要框架侦听的属性。

(curVal,preVal)={ //业务处理}箭头函数,是最新的监控值,也是本次修改前的值。这里,执行逻辑处理。

选项:配置项,监听器的配置,比如是否深度监听。

页面首次进入时不会被执行。当值发生变化时,将打印出当前最新值和修改前的值。

示例1:监控一个数据。

从“vue”导入{ref,watch }

exportdefault{

设置(){ 0

constmood=ref(')

//帧监听器

手表(心情,(曲线,预判)={ 0 }

console.log('cur ',curVal);

console.log('pre ',普雷瓦尔);

},{

//配置项

})

返回{

情绪

}

}

}watch还可以监控多个属性值,传入的数据变成一个数组,配置项保持不变。

1.2、watch 监听多个属性值

示例2:监视器多个属性

手表([心情,目标],([心情,目标],[心情,目标],[心情,目标])={ 0

console.log('curMood ',curMood);

console.log('preMood ',pre mood);

console.log('curTarget ',curTarget);

console.log('preTarget ',preTarget);

},{

//配置项

})

1.3、watch 监听引用数据类型

watch监控引用数据类型时,如果只监控一个属性,

使用语法如下:

watch(()=obj.name,(curValue,preval)={ 0 }

//帧侦听引用数据类型的某个属性

},{

//配置项

})第一个参数,回调函数返回需要监听的对象的属性。背面的参数与顶部的参数相同。

示例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>

感谢各位的阅读,以上就是“vue3中watch和watchEffect怎么使用”的内容了,经过本文的学习后,相信大家对vue3中watch和watchEffect怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/127855.html

(0)

相关推荐

  • 有草有水的寓意好的字,带火的字而且寓意好的有哪些

    技术有草有水的寓意好的字,带火的字而且寓意好的有哪些“火”字旁的常用字有草有水的寓意好的字: 火(huo 4画)    灯(deng 16画)  灿(can 7画)    炀(yang 13画)  炜(wei 13画) 

    生活 2021年10月24日
  • python如何爬取基金股票最新数据并用excel绘制树状图

    技术python如何爬取基金股票最新数据并用excel绘制树状图python如何爬取基金股票最新数据并用excel绘制树状图,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到

    攻略 2021年10月26日
  • 怎么解决css加载外部字体乱码问题

    技术怎么解决css加载外部字体乱码问题本篇内容介绍了“怎么解决css加载外部字体乱码问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,

    攻略 2021年11月17日
  • 微信朋友圈只发文字,朋友圈为什么不能直接发文字

    技术微信朋友圈只发文字,朋友圈为什么不能直接发文字微信朋友圈是可以直接发文字的,步骤如下微信朋友圈只发文字:
    1.登陆微信。
    2.在微信界面当中点击发现选项。
    3.然后在发现界面打开朋友圈。
    4.在朋友圈界面上长按相机图

    生活 2021年10月23日
  • Linux字符设备控制怎么实现

    技术Linux字符设备控制怎么实现本篇内容介绍了“Linux字符设备控制怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有

    攻略 2021年11月23日
  • ORACLE中出现ORA-28365错误怎么办

    技术ORACLE中出现ORA-28365错误怎么办这篇文章主要为大家展示了“ORACLE中出现ORA-28365错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ORA

    攻略 2021年11月20日