Vue3子组件watch无法监听父组件传递的属性值
Vue3子组件watch无法监听父组件传递的属性值
1 问题描述
假设子组件 ChildComponent
中有个属性a,默认值为 0,并且通过侦听器 watch 监听其数值变化。在父组件 ParentComponent
中调用子组件并将属性a的值赋为1传递给子组件,发现子组件模板中a的值是1,但是 watch 并未监听到属性a的值发生了变化。
子组件示例代码:
<template>
<!-- a的值显示为1 -->
<div>{{ a }}</div>
</template>
<script setup>
import { watch } from 'vue'
const props = defineProps({
a: {
type: Number,
default: 0
}
})
watch(
() => props.a,
(newValue, oldValue) => {
console.log('a has changed', newValue, oldVlue)
}
)
</script>
父组件示例代码:
<template>
<ChildComponent :a="1" />
</template>
2 引发原因
Vue官网:watch 默认是懒执行的:仅当数据源变化时,才会执行回调。
Vue 在渲染模板时,先渲染子组件,然后渲染父组件。子组件在初始化时,属性a的值被赋为默认值0,然后父组件进行初始化,将 a=1
传递给子组件,子组件接收后将新值覆盖掉原来的旧值,完成初始化。由于子组件属性是响应式的,所以从0变化为1后,会更新模板视图。该过程发生在组件初始化阶段,watch 函数首次进行绑定,不认为数据源发生了变化,所以不会执行回调。
3 解决方法
Vue 提供了 immediate
属性,设置该属性后可以让 watch 函数首次绑定后立即执行一次回调,获取最新的属性值。
watch(
() => props.a,
(newValue, oldValue) => {
console.log('a has changed', newValue, oldVlue)
},
{ immediate: true }
)
原文地址:https://blog.csdn.net/Alan_Walker688/article/details/142824199
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!
-
天通卫星电话|移动手持终端|5G军工手持终端|全星魅
在当今这个信息瞬息万变的时代,通信技术作为连接世界的桥梁,其重要性不言而喻。随着科技的飞速发展,传统的通信手段已难以满足人们在极端环境或偏远地区的通信需求。于是,一款集高科技与实用性于一身的双模卫星电
阅读更多2024-10-16
-
【大模型系列】Qwen2-VL(2024.10)
Qwen团队开源了Qwen2-VL系列模型,支持多语言图像文本理解、代码/数学推理、视频分析、实时聊天、代理等。支持动态分辨率输入,并在训练过程中引入了2D-RoPE,从而使模型更好的捕获不同空间尺度
阅读更多2024-10-16
-
Java之IO流详解
Java 的输入输出(IO)系统是 Java 编程的核心部分之一,用于处理数据的读写操作。Java 提供了一套强大的 API 来处理不同类型的 IO 操作,包括文件读写、网络传输、内存操作等。
阅读更多2024-10-16
-
MySQL 安装和基本使用
MySQL 的特性MySQL 是基于开源协议发布的,可以免费使用,也可以基于源码进行二次开发。MySQL 使用标准 SQL 语言进行管理。MySQL 可以运行于多个系统上,具有跨平台特性,并且支持多种
阅读更多2024-10-16
-
10.15学习
变量的类型定义了它可以存储的值的范围。例如, int 类型可以存储的整数范围通常在 -2,147,483,648 到 2,147,483,647 之间(具体范围取决于系统的位数),而 float
阅读更多2024-10-16
-
每日OJ题_WY3小易的升级之路_数学模拟_C++_Java
每日OJ题_WY3小易的升级之路_数学模拟_C++_Java(本题的能力值的累加分两种情况,一种是直接相加bi,一种是累加当前能力值于bi的最大公约数。最大公约数可以通过碾转相除法求得:
阅读更多2024-10-16
-
Vue3嵌套导航相对路径问题
可以参考下面的a标签,也是这样跳转的,个人觉得在当前路径是http://localhost:5173/news的时候,访问相对路径detail,就相当于一个文件夹是http://localhost:5
阅读更多2024-10-16
-
5款实用的文字转语音工具,简单几步完成转换,你值得拥有(收藏)
不知道大家对文字语音转换软件了解有多少,随着互联网科技的发展,现在很多文字转语音软件已逐渐融入我们的日常生活。有需要的小伙伴们快点接着往下看吧!以上就是小编给大家分享的几个文字语音转换工具了,我们可以
阅读更多2024-10-16
-
anatraf抓包分析仪与网络故障排除
抓包分析仪是一种能够捕获、记录并分析网络数据包的设备或软件工具,它能够提供实时的网络流量分析,并帮助管理员深入了解网络的运作机制。抓包分析仪可以帮助企业在日常的网络运维中,识别出可能影响网络性能的瓶颈
阅读更多2024-10-16
-
C++运算出现整型溢出
答案也是编不过的,要想编过,需要将b改成long类型,这是因为运算时会发生隐式类型转换,a的int类型会转换为更长的long,从而暂存值一直是long,不会溢出。请记住,c语言没有赋值,只有表达式,右
阅读更多2024-10-16