vue父组件给子组件传值,子组件不渲染的原因及解决方法

父组件传递给子组件的数据,如果是一个复杂对象(例如一个数组或对象),那么子组件只会监听对象的引用而不是对象的内容。这意味着当对象的内容发生变化时,子组件不会更新。

解决:

1、在子组件使用 watch 监听 props传过来的值,如果发现改变,调用forceUpdate刷新视图。

复制代码
this.$forceUpdate()

2、父组件中声明一个布尔变量,数据发生变化后,切换一下变量状态,可刷新子组件视图。

3、数据发生变化后,在下面调用一下splice方法修改原数组长度(索引、截取长度都为0),数组不变,但视图可成功渲染。

复制代码
this.list.splice(0, 0)
相关推荐
Sahas10191 分钟前
__VUE_PROD_HYDRATION_MISMATCH_DETAILS__ is not explicitly defined.
前端·javascript·vue.js
Jinxiansen021111 分钟前
Vue 3 实战:【加强版】公司通知推送(WebSocket + token 校验 + 心跳机制)
前端·javascript·vue.js·websocket·typescript
MrSkye12 分钟前
React入门:组件化思想?数据驱动?
前端·react.js·面试
BillKu21 分钟前
Java解析前端传来的Unix时间戳
java·前端·unix
@Mr_LiuYang21 分钟前
网页版便签应用开发:HTML5本地存储与拖拽交互实践
前端·交互·html5·html5便签应用
JohnYan24 分钟前
Bun技术评估 - 05 SQL
javascript·后端·bun
JacksonGao25 分钟前
一分钟带你了解React Fiber的工作单元结构!
前端·react.js
前端农民晨曦26 分钟前
深入浏览器事件循环与任务队列架构
前端·javascript·面试
Vhen28 分钟前
Taro Echarts封装内外环形饼图
前端
Spider_Man42 分钟前
JavaScript对象那些坑:初学者必踩的“陷阱”与进阶秘籍
前端·javascript