选项式API与之前写法相同,本篇文章主要通过 Options API 和 Composition API 对比 watch 的使用方法,让您快速掌握 vue3 中 watch 新用法。建议收藏!

一、watch 新用法

选项式API中,watch 使用

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

2.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 也可以监听多个属性值,此时传入的数据变成数组形式,配置项保持不变。

2.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);
},{
//配置项
})

2.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的特点为:

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

3.2、watch 配置项

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

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

3.3、watchEffect 特点

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

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

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>

好了小编今天的文章就到此结束了,喜欢我的可以点个关注哦!

最新文章

  1. call和apply的区别
  2. 玩转 HTML5 Placeholder
  3. hdu3652
  4. 【转】关于KDD Cup '99 数据集的警告,希望从事相关工作的伙伴注意
  5. [py]安装ipython
  6. mybatis系列-04-mybatis开发dao的方法
  7. 关于vs2008使用oracleclient链接oracle数据库报报错OCIEnvCreate 失败,返回代码为 -1,但错误消息文本不可用
  8. 软键盘 输入法管理器 InputMethodManager
  9. git 忽略已跟踪的文件
  10. static成员是可以被其所在class创建的实例访问!!!
  11. Dashboard登录成功后 RuntimeError: Unable to create a new session key.
  12. IDEA 无法运行Junit, 报错Class not found xxxx Empty test suite.
  13. Jmeter_beanshell实现字符串加密
  14. 学习java接口知识
  15. JAVA项目启动正常,无法访问
  16. 【搬运工】修改mysql数据库的时区
  17. OpenStack IceHouse 部署 - 1 - 架构说明
  18. iperf使用
  19. PL/SQL 09 包 package
  20. Solr6.6.0 用 SimplePostTool索引文件 中文乱码

热门文章

  1. Django实现用户登录注册
  2. 【UE4 材质】一些小功能
  3. VS Code Remote SSH设置
  4. Mybatis 动态Sql练习
  5. 通过简单例子 | 快速理清 UML 中类与类的六大关系
  6. 如何再一台电脑上配置多个tomcat同时运行
  7. Noip模拟30 2021.8.4
  8. VS2017+QT5.12.10+QGIS3.16环境搭建及开发全流程
  9. 数字设计中的时钟与约束(gate)
  10. C++ Qt 项目实战(一)之文本编辑器