Vue3中的watch监听

一、监听基础ref类型

1、监听单个ref数据

在这里插入图片描述

在这里插入图片描述

2、 监听多个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}才能触发监听
在这里插入图片描述
在这里插入图片描述

三、watchEffect

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

  1. watch可以访问新值和旧值,watchEffect不能访问。
  2. watch需要指明监听的对象,也需要指明监听的回调。
  3. watchEffect不用指明监视哪一个属性,监视的回调函数中用到哪个属性,就监视哪个属性。
    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>
  • 8
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值