uniapp中父组件传参到子组件页面渲染不生效问题处理实战记录

上篇文件介绍了,父组件数据更新正常但是页面渲染不生效的问题,详情可以看下:uniapp中父组件数组更新后与页面渲染数组不一致实战记录

本文在此基础上由于新增需求衍生出新的问题.本文只记录一下解决思路.

下面说下新增需求方便理解场景:

商品信息设置中添加抽奖概率设置,默认概率相同,页面如下:

可以切换成自定义.显示概率输入框,页面如下:

处理逻辑中给goodsList的每个详情中根据业务场景添加了对应属性:

c 复制代码
"sameRate": 1, // 1.概率相同;2.自定义
"prizeRate": 0,  // sameRate为2时有效

子组件中sameRate为1显示相同,sameRate为2时显示概率输入框.

出现问题 :

显示设置radio切换逻辑中添加了goodsList中每个对象属性sameRate进行变更的处理逻辑.控制台发现goodsList数据变化显示正常.goodsList中每个对象属性sameRate会随着显示设置切换正常变化,统一为1或是统一为2.但是子组件显示的三个商品信息概率一栏中只会显示相同(sameRate为1),无法跟随显示设置动态变化.

问题原因:

这里涉及到父页面数据变换后如何让子组件重新渲染的问题,一般来讲父组件中数据变换通过props传递到子组件进行重新渲染.我这边出现问题的原因是子组件采用了自定义key.页面初始化后已经是固定值.vue中默认子组件中唯一key变化后才会重新渲染子组件.所以处理办法是在radio切换逻辑中变更goodsList中每个对象属性的key值.

相关推荐
feVA LTYR10 小时前
Windows上安装Go并配置环境变量(图文步骤)
开发语言·windows·golang
ZC跨境爬虫10 小时前
UI前端美化技能提升日志day7:(原生苹方字体全局适配+合规页脚完整像素级落地)
前端·javascript·ui·html·交互
好运的阿财10 小时前
OpenClaw工具拆解之tts+web_search
前端·javascript·python·ai·ai编程·openclaw·openclaw工具
hhb_61810 小时前
C#高性能异步编程实战与底层原理深度解析
开发语言·c#
雾岛听蓝10 小时前
Qt操作指南:状态栏、浮动窗口与对话框使用
开发语言·经验分享·笔记·qt
whinc11 小时前
Node.js技术周刊 2026年第17周
前端·javascript
nbsaas-boot11 小时前
100万门店级分货系统架构设计
前端·javascript·vue.js
minji...11 小时前
Linux 线程同步与互斥(五) 日志,线程池
linux·运维·服务器·开发语言·c++·算法
兩尛11 小时前
c++面试常问2
开发语言·c++·面试
l1t11 小时前
DeepSeek v4辅助生成的单文件SQL查询示例页面
javascript·数据库·sql