vue3子组件数据无法更新问题

 更新时间:2023年10月07日 10:50:47   作者:嘉然今天刷算法  
这篇文章主要介绍了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中的操作。

总结

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

相关文章

  • 简单实现vue中的依赖收集与响应的方法

    简单实现vue中的依赖收集与响应的方法

    这篇文章主要介绍了简单实现vue中的依赖收集与响应的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • VUE+Element实现增删改查的示例源码

    VUE+Element实现增删改查的示例源码

    这篇文章主要介绍了VUE+Element实现增删改查的示例源码,帮助大家更好的理解和使用vue,感兴趣的朋友可以了解下
    2020-11-11
  • 简单谈谈Vue3中的ref和reactive

    简单谈谈Vue3中的ref和reactive

    vue3中实现响应式数据的方法是就是使用ref和reactive,所谓响应式就是界面和数据同步,能实现实时更新,下面这篇文章主要给大家介绍了关于Vue3中ref和reactive的相关资料,需要的朋友可以参考下
    2023-04-04
  • Vue3 编写自定义指令插件的示例代码

    Vue3 编写自定义指令插件的示例代码

    这篇文章主要介绍了Vue3 编写自定义指令插件的示例代码,主要包括编写自定义插件,在 main.ts 中加载启用插件的代码介绍,对Vue3自定义指令插件相关知识感兴趣的朋友一起看看吧
    2022-07-07
  • vue仓库的使用方式

    vue仓库的使用方式

    这篇文章主要介绍了vue仓库的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-09-09
  • Vue中keep-alive组件的深入理解

    Vue中keep-alive组件的深入理解

    这篇文章主要给大家介绍了关于Vue中keep-alive组件的深入理解,文中通过实例代码结束的非常详细,对大家学习或者使用Vue具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-08-08
  • Vue中ref的用法及演示

    Vue中ref的用法及演示

    这篇文章主要介绍了Vue中ref的用法及演示,ref被用来给元素或子组件注册引用信息。引用信息会被注册在父组件上的$refs对象上,下面来看看文章的详细内容,需要的朋友可以参考一下
    2021-11-11
  • vue中实现高德定位功能

    vue中实现高德定位功能

    这篇文章主要介绍了vue中实现高德定位功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • Vue 固定头 固定列 点击表头可排序的表格组件

    Vue 固定头 固定列 点击表头可排序的表格组件

    这篇文章主要介绍了Vue 固定头 固定列 点击表头可排序的表格组件的相关资料,需要的朋友可以参考下
    2016-11-11
  • Message组件实现发财UI 示例详解

    Message组件实现发财UI 示例详解

    这篇文章主要为大家介绍了Message组件实现发财UI的手写示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08

最新评论