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

相关推荐
gnip2 小时前
Jst执行上下文栈和变量对象
前端·javascript
excel2 小时前
🐣 最简单的卷积与激活函数指南(带示例)
前端
醉方休3 小时前
npm/pnpm软链接的优点和使用场景
前端·npm·node.js
拉不动的猪3 小时前
简单回顾下Weakmap在vue中为何不能去作为循环数据源,以及替代方案
前端·javascript·vue.js
How_doyou_do3 小时前
数据传输优化-异步不阻塞处理增强首屏体验
开发语言·前端·javascript
奇舞精选3 小时前
超越Siri的耳朵:ASR与Whisper零代码部署实战指南
前端·人工智能·aigc
奇舞精选3 小时前
Nano Banana 如何为前端注入 AI 控制力
前端·aigc
一支鱼3 小时前
基于 Node.js 的短视频制作神器 ——FFCreator
前端·node.js·音视频开发
DT——3 小时前
前端登录鉴权详解
前端·javascript
李姆斯4 小时前
复盘上瘾症:到底什么时候该“复盘”,什么时候不需要“复盘”
前端·后端·团队管理