vue3子组件数据无法更新问题
作者:嘉然今天刷算法
这篇文章主要介绍了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中的操作。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。