本文主要讲解“如何在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
特点。
示例5:watch
监听对象
<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