Vue3 watch监视和watchEffect函数

本文详细比较了Vue3中watch的使用,包括监视ref对象、reactive对象、数组和深度监视,以及watchEffect函数的区别。介绍了配置immediate和deep选项,并指出watchEffect的自动特性。

Vue3 中的watch使用效果和Vue2 中配置watch配置项的使用效果是一致的。

使用watch监视之前,需要先对watch进行引入。

import {watch} from 'vue';

一、监视一个ref对象

以下情况只适用于监视一个ref对象。

watch(监视对象, (newValue, oldValue) => {  // 监视操作  }, {  // 配置项  })

配置项中可以开启两个配置项:

1. immediate  是否初始化时对监视属性进行一次监听。

2. deep  是否开启深度监视。

使用ref定义的数据一般都是普通数据类型,不需要开启深度监视。

 

setup() {
  let num1 = ref(0);

  watch(num1, (newValue, oldValue) => {
    console.log(`num1从${oldValue}变为了${newValue}`);
  })

  return {
    num1,
  };
},

如果我们监视的是一个传入值为对象类型的ref 的对象,这种情况下我们是不能对该对象进行监听的,两种解决方法:

1. 使用.value 对数据进行监听,因为ref 对象的value值为一个reactive 对象

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值