开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法

需求

Vue3 中如何遍历list并修改list元素的属性的值?

解决办法

1、‌使用 map 方法‌

vue 复制代码
const newList = list.value.map(item => {
  return {
    ...item,
    modifiedProperty: 'newValue' // 修改的属性名称和属性值
  }
})

Vue 中的 map() 函数是 JavaScript 数组的高阶函数,主要用于遍历数组并返回新数组,常用于数据处理和响应式更新。

特点‌:不修改原数组,返回处理后的新数组。

典型场景‌:转换数据格式、修改元素属性的值或提取特定属性。

...item 包含两个关键部分:

item‌:代表列表渲染 (v-for) 中当前遍历的元素,它是数组或对象迭代项的别名变量。

示例:v-for="item in items" 中,item 是数组 items 的单个元素可通过 item.属性名 访问具体数据(如 item.id

...(展开运算符)‌:‌作用‌是将 item 对象的所有属性展开为新对象的属性。

2、‌使用 forEach()方法‌

使用 forEach()函数 直接修改原数组。在 Vue 中,forEach() 是 JavaScript 数组的原生方法,用于遍历数组元素并执行回调函数,但不会返回新数组。

vue 复制代码
list.value.forEach(item => {
	item.oid=null;//将list元素的oid属性设置为null
});

基础语法:

vue 复制代码
array.forEach((item, index, arr) => {
  // 操作逻辑
})

‌参数说明‌:

item:当前遍历的元素

index(可选):当前元素的索引

arr(可选):原数组本身

相关推荐
boooooooom10 小时前
手写简易Vue响应式:基于Proxy + effect的核心实现
javascript·vue.js
王同学 学出来10 小时前
vue+nodejs项目在服务器实现docker部署
服务器·前端·vue.js·docker·node.js
一道雷10 小时前
让 Vant 弹出层适配 Uniapp Webview 返回键
前端·vue.js·前端框架
bug总结10 小时前
uniapp+动态设置顶部导航栏使用详解
java·前端·javascript
晴殇i10 小时前
深入理解MessageChannel:JS双向通信的高效解决方案
前端·javascript·程序员
毕设十刻10 小时前
基于Vue的民宿管理系统st4rf(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
kkkAloha10 小时前
倒计时 | setInterval
前端·javascript·vue.js
云轩奕鹤10 小时前
智析单词书 - AI 驱动的深度英语词汇学习平台
前端·ai·产品·思维
逆光如雪11 小时前
控制台快速查看自己的log,提高开发效率
前端
用户479492835691511 小时前
年薪百万的 React 功底怎么“装进”AI?Vercel 的这个 Skill 给了标准答案
前端·aigc·ai编程