vue3子组件数据无法更新问题
vue3子组件数据无法更新
在写vue3代码时,遇到了父组件传值给子组件,但是子组件无法及时刷新数据,父组件数据是异步获取的。
使用了很多方法,froceUpdate(),nextTick之类的方法都试过了没有生效。
所以需要在父组件对子组件进行刷新。
解决思路
利用vue diff算法的特点,更新key,强制使子组件刷新
代码:
//dom //给需要刷新的子组件加上一个自定义的key <v-number :num="memoryNum" :fontSize="28" class="number" :key="keyNum"></v-number> //ts //所有数据加载完毕之后,更改这个key即可 let keyNum = ref(0); onMounted(async () => { await init(); keyNum.value++; });
vue3子组件数据无法更新
问题描述
子组件接收到父组件传递的prop数据后,在created 中进行一番预处理,再赋值给模板,而当在父组件中改变prop数据,子组件的视图未发生改变。
原因
子组件并没有重新加载,所以不会再次执行created或者mounted,子组件也就未处理改变的prop数据,视图也就不会更新。
解决办法
子组件上加上唯一的key,传入的props不同时,key值也不同,这样当切换prop数据的时候,由于key不同,vue会认为是两个不同的组件,就会重新执行组件的created或者mounted中的操作。
<Child :data="data" :key="data.id"></Child>
在子组件使用 watch 监听(可能需要深度监听)props传过来的值,如果发现改变,再次执行created或者mounted中的操作。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue2 el-table行悬停时弹出提示信息el-popover的实现
本文主要介绍了vue2 el-table行悬停时弹出提示信息el-popover的实现,用到了cell-mouse-enter、cell-mouse-leave两个事件,具有一定的参考价值,感兴趣的可以了解一下2024-01-01Vue利用computed配合watch实现监听多个属性的变化
这篇文章主要给大家介绍了在Vue中巧用computed配合watch实现监听多个属性的变化的方法,文中有详细的代码示例供大家参考,具有一定的参考价值,需要的朋友可以参考下2023-10-10
最新评论