Vue3中的watch监听

目录

目录

一、监听基础ref类型

1、监听单个ref数据

2、 监听多个ref数据

3、监听ref对象

4、监听ref对象中的单个值

5、监听ref对象中的单个对象

二、监听reactive类型

1、监听对象中单个属性

 2、监听对象中多个属性

  3、同时监听ref基本类型数据和reactive对象中的属性

 4、监听整个对象

  5、监听对象中值为对象的属性

三、watchEffect

四、监听计算属性computed


一、监听基础ref类型

1、监听单个ref数据

2、 监听多个ref数据

3、监听ref对象

 

4、监听ref对象中的单个值

5、监听ref对象中的单个对象

二、监听reactive类型

1、监听对象中单个属性

监听 user.more.iPhone 属性,那么只有当iPhone属性发生变更时,才会触发 watch 方法,其他属性变更不会触发 watch 方法。注意,此时的第一个参数是一个箭头函数

 2、监听对象中多个属性

  3、同时监听ref基本类型数据和reactive对象中的属性

 

 4、监听整个对象

当监听整个对象时,只要这个对象有任何修改,那么就会触发 watch 方法。无论是其子属性变更(如 user.name),还是孙属性变更(如 user.more.iPhone)...,都是会触发 watch 方法的。

  5、监听对象中值为对象的属性

方式1:不用箭头函数,则可以不用deep:true

 方式二【推荐用箭头函数】:用箭头函数时,则必须加上{deep:true}才能触发监听

我们发现newValue和oldValue的值都是一样的, 这是因为它们的引用指向同一个对象/数组

 推荐用箭头函数监听对象的原因就是,我们可以通过以下方式来使新旧值不一样

如果直接监听对象,别说监听对象的改变了,直接原对象都监听不到,如下:

 总结:监听对象时,如果不关心旧值,那么直接监听对象更方便,因为不用手动设置deep为true;如果关心旧值,那么需要使用箭头函数,并序列化,设置deep:true

三、watchEffect

不用指明监视哪个属性,监视的回调用到哪个属性,就去监视哪个属性

  1. watch可以访问新值和旧值,watchEffect不能访问。
  2. watch需要指明监听的对象,也需要指明监听的回调。watchEffect不用指明监视哪一个属性,监视的回调函数中用到哪个属性,就监视哪个属性。
  3. watch只有监听的值发生变化的时候才会执行,但是watchEffect不同,每次代码加载watchEffect都会执行。

<template>
  <div>nums:<input v-model="nums" /></div>
  <div>user.age:<input v-model="user.age" /></div>
  <button @click="user.more.iPhone = 22222">改变more</button>
</template>
<script setup>
const nums = ref(1);

const user = reactive({
  name: "张三",
  age: 23,
  more: {
    iPhone: 1111,
    address: "aaa",
  },
});
watchEffect(() => {
  const x1 = nums.value;
  const x2 = user.age;
  const x3 = user.more.iPhone;

  console.log("watchEffect监听的回调执行了...");
});
watchEffect(() => {
  console.log("222222222...");
});
</script>

四、监听计算属性computed

  • 10
    点赞
  • 113
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue3,我们可以使用watch函数来监听数据的响应式变化。watch函数的基本用法是将要监听的数据作为第一个参数,副作用函数作为第二个参数,并且可以通过配置对象进行一些额外的设置。例如: watch(data, (newData, oldData) => { // 副作用函数 }, { immediate: true, deep: true }) 在这个例子,data是要监听的数据,(newData, oldData)是副作用函数,它会在数据发生变化时被调用。配置对象{ immediate: true, deep: true }可以设置监听的行为,immediate为true表示在初始化时立即执行一次副作用函数,deep为true表示深度监听,即递归监听对象内部的变化。 另外,Vue3允许同时存在多个watch监听器。你可以分别监听不同的数据,并在副作用函数处理它们的变化。例如: watch(name, (newValue, oldValue) => { console.log("new", newValue, "old", oldValue); }); watch(age, (newValue, oldValue) => { console.log("new", newValue, "old", oldValue); }); 这样,当name或age发生变化时,对应的副作用函数就会被调用,并打印出新旧值。 综上所述,在Vue3,我们可以使用watch函数来监听数据的响应式变化,并通过配置对象进行一些额外的设置。同时,我们也可以同时存在多个watch监听器来监听不同的数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue3基础之watch监听](https://blog.csdn.net/weixin_64740434/article/details/131619855)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [VUE3的watch监听使用](https://blog.csdn.net/moxunjinmu/article/details/123219081)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值