vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > vue3子组件数据无法更新

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中的操作。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文