当前位置: 首页 > news >正文

uniapp中父组件数组更新后与页面渲染数组不一致实战记录

    简单描述一下业务场景方便理解:
    商品设置功能,支持添加多组商品(点击添加按钮进行增加).可以对任意商品进行删除(点击减少按钮对选中的商品设置进行删除).
在这里插入图片描述
问题:
    正常添加操作后,对已添加的任意商品删除后,控制台打印数组正常.但是与页面显示不一致.已上图为例,选中尾号2885进行删除,控制台商品数组显示正常,存在尾号6719和尾号7040的商品.但是页面显示还是尾号2885和尾号6719商品信息.尾号7040的商品不显示.
    多次测试发现不论选中哪个商品设置,控制台打印的数组与预期删除的一致,但是页面始终是最后一个尾号7040的商品不显示.
这里尝试过很多办法,最终出现问题是在v-for循环中的key,修改之前的父组件:

<goods_settting v-for="(goodsItem,index) in goodsList" :key="index"
</goods_settting >

    造成上述问题的原因是在删除数组中指定元素后对数组进行重新赋值,key存在重复的情况导致渲染异常.
修改后:

<goods_settting v-for="(goodsItem,index) in goodsList" :key="goodsItem.goodsId"
</goods_settting >

    这里的goodsItem.goodsId必须保证是唯一的,入页面所示显示的是时间戳.

http://www.lryc.cn/news/495015.html

相关文章:

  • 优化 Conda 下载速度:详细的代理配置和网络管理策略
  • 服务器遭受DDoS攻击后如何恢复运行?
  • MFC音视频播放器-支持电子放大等功能
  • c语言编程1.17蓝桥杯历届试题-回文数字
  • el-table 纵向 横向 多级表头
  • uniapp开发微信小程序笔记8-uniapp使用vant框架
  • 分布式项目使用Redis实现数据库对象自增主键ID
  • npm-运行项目报错:A complete log of this run can be found .......npm-cache_logs\
  • SolarCube: 高分辨率太阳辐照预测基准数据集
  • 华为小米苹果三星移动设备访问windows共享文件夹windows11
  • 网络安全三防指南:只防病毒不安全
  • 论文概览 |《Urban Analytics and City Science》2023.05 Vol.50 Issue.4
  • 【ROS2】ROS2 C++版本 与 Python版本比较
  • 物联网射频识别和RFID开发(一):RFID基础—概念、应用
  • JVM:即时编译器,C2 Compiler,堆外内存排查
  • webpack5 的五大核心配置(二)
  • 【查询基础】.NET开源 ORM 框架 SqlSugar 系列
  • git push使用
  • 【iOS】多线程基础
  • 常用网站网址
  • go语言切片
  • 鸿蒙NEXT元服务:利用App Linking实现无缝跳转与二维码拉起
  • 网络药理学之薛定谔Schrödinge Maestro:6、分子对接(Glide、Ligand docking)和可视化
  • 已解决ModuleNotFoundError: No module named ‘selenium‘
  • 【Maven】依赖冲突如何解决?
  • 什么是EMS
  • 26页PDF | 数据中台能力框架及评估体系解读(限免下载)
  • 【Vue3】【Naive UI】< a >标签
  • 分页查询日期格式不对
  • DAY140权限提升-Linux系统权限提升篇VulnhubPATH变量NFS服务Cron任务配合SUID