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

解决vue2中更新列表数据,页面dom没有重新渲染的问题

在 Vue 2 中,直接修改数组的某个项可能不会触发视图的更新。这是因为 Vue 不能检测到数组的索引变化或对象属性的直接赋值。为了确保 Vue 能够正确地响应数据变化,你可以使用以下几种方法:

1. 使用 Vue.set()

使用 Vue.set() 方法可以确保 Vue 能够检测到数组或对象的变化并重新渲染视图。你的代码可以修改为:

案例场景:在子组件中修改数据后,通过子组件的this.$emit触发父组件中,给子组件绑定的自定事件对应的函数updateList,其中obj通过子组件传递过来
updateList(obj) {let index = this.list.findIndex(item => parseInt(item.id) === parseInt(obj.id));if (index !== -1) {// 使用 Vue.set() 更新数组中的项this.$set(this.list, index, obj);}
}

2. 使用 splice() 方法

你也可以使用 splice() 方法来替换数组中的项,这样 Vue 会检测到变化:

updateList(obj) {let index = this.list.findIndex(item => parseInt(item.id) === parseInt(obj.id));if (index !== -1) {// 使用 splice() 替换项this.list.splice(index, 1, obj);}
}

3. 创建一个新数组

另外一种方法是创建一个新的数组并替换旧数组,这样 Vue 也会检测到变化:

updateList(obj) {this.list = this.list.map(item => {return parseInt(item.id) === parseInt(obj.id) ? obj : item;});
}

总结

使用 Vue.set() 或 splice() 是最常见的做法,可以确保 Vue 的响应式系统正确工作,及时更新视图。选择适合你需求的方法即可。

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

相关文章:

  • vscode通过ssh连接远程服务器(实习心得)
  • 知识图谱9:知识图谱的展示
  • leetcode 面试经典 150 题:验证回文串
  • 【0363】Postgres内核 从 XLogReaderState readBuf 解析 XLOG Record( 8 )
  • docker tdengine windows快速体验
  • 详解RabbitMQ在Ubuntu上的安装
  • Python的3D可视化库【vedo】2-2 (plotter模块) 访问绘制器信息、操作渲染器
  • 【vue2】文本自动省略组件,支持单行和多行省略,超出显示tooltip
  • 网络安全产品之认识防病毒软件
  • 游戏引擎学习第42天
  • 区块链智能合约( solidity) 安全编程
  • GUNS搭建
  • 【ETCD】【源码阅读】stepWithWaitOption方法解析
  • redis 怎么样查看list
  • E: 无法获取 dpkg 前端锁 (/var/lib/dpkg/lock-frontend),是否有其他进程正占用它?
  • 创建型设计模式
  • 仿iOS日历、飞书日历、Google日历的日模式
  • vuedraggable
  • 新手从事直播软件源码开发搭建经验与技巧
  • 相机不动,机构动作----Hands Eyes
  • Scala的导入
  • vue2中父子组件传值案例总结
  • 功能篇:springboot中实现文件导出
  • Redis客户端(Jedis、RedisTemplate、Redisson)
  • Mybatis中SQL的执行过程
  • 【数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
  • 【论文阅读】PRIS: Practical robust invertible network for image steganography
  • 在Linux桌面系统普及化方面的一些建议
  • LLM - 多模态大模型的开源评估工具 VLMEvalKit 部署与测试 教程
  • 数据结构(Queue队列)