开发避坑指南(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(可选):原数组本身

相关推荐
橙序员小站1 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名3 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫4 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊4 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter4 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折4 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_4 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
不会敲代码14 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
Angelial4 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
jiayu5 小时前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端