news 2026/4/23 17:09:17

在前端中list.map的用法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在前端中list.map的用法

在前端(JavaScript)中,Array.prototype.map()是数组的核心高阶方法,用于遍历数组并返回一个新数组—— 新数组的每个元素是原数组元素经过指定回调函数处理后的结果。它不会修改原数组,是纯函数式编程的常用工具,广泛用于 React/Vue 等框架的列表渲染、数据转换等场景。

一、基本语法

javascript

运行

const newArray = array.map((currentValue, index, array) => { // 处理逻辑,返回新值 }, thisArg);
参数说明
currentValue必选,当前遍历到的数组元素
index可选,当前元素的索引值
array可选,调用map的原数组本身
thisArg可选,执行回调函数时this的指向(箭头函数不生效,因箭头函数绑定外层this
返回值newArray新数组,长度与原数组一致,元素为回调函数的返回值

二、核心特性

  1. 不修改原数组:仅返回新数组,原数组保持不变;
  2. 遍历所有元素:不会跳过undefined/null元素(但空数组不执行回调);
  3. 返回数组长度与原数组一致:即使回调无返回值,新数组元素为undefined

三、常见使用场景

1. 基础:数据格式转换

最常用场景 —— 将原数组的每个元素转换为新格式(如数字转字符串、对象属性提取)。

javascript

运行

// 示例1:数字数组转字符串数组 const nums = [1, 2, 3]; const strNums = nums.map(num => num.toString()); console.log(strNums); // ["1", "2", "3"] // 示例2:提取对象数组的指定属性 const users = [ { id: 1, name: "张三" }, { id: 2, name: "李四" }, { id: 3, name: "王五" } ]; const userNames = users.map(user => user.name); console.log(userNames); // ["张三", "李四", "王五"]
2. 前端框架核心:列表渲染(React/Vue)
  • React 中map是渲染列表的标准方式,需为每个子元素加key(推荐用唯一标识,而非索引)。

    jsx

    const TodoList = () => { const todos = ["吃饭", "睡觉", "写代码"]; return ( <ul> {todos.map((todo, index) => ( <li key={index}>{todo}</li> // 简单场景可用index,复杂场景用唯一id ))} </ul> ); };
  • Vue 中:虽常用v-for,但底层也可结合map处理数据后渲染:

    vue

    <template> <ul> <li v-for="item in processedList" :key="item.id">{{ item.name }}</li> </ul> </template> <script> export default { data() { return { list: [{ id: 1, name: "苹果" }, { id: 2, name: "香蕉" }] }; }, computed: { processedList() { // 转换数据格式后渲染 return this.list.map(item => ({ ...item, name: item.name + "(水果)" })); } } }; </script>
3. 进阶:带索引 / 原数组的处理

利用indexarray参数实现更复杂的逻辑(如给元素加序号、对比原数组)。

javascript

运行

const arr = ["a", "b", "c"]; // 给每个元素加序号(索引+1) const numberedArr = arr.map((item, index) => `${index + 1}. ${item}`); console.log(numberedArr); // ["1. a", "2. b", "3. c"] // 对比当前元素与原数组第一个元素 const compareArr = arr.map((item, _, original) => item === original[0]); console.log(compareArr); // [true, false, false]
4. 注意:避免误用(与 forEach 区分)

map是 “转换并返回新数组”,若仅需遍历执行操作(无返回值),应使用forEach,否则会生成无意义的undefined数组:

javascript

运行

// 错误用法:仅遍历打印,却用map(生成[undefined, undefined]) const arr = [1, 2]; const wrong = arr.map(num => console.log(num)); console.log(wrong); // [undefined, undefined] // 正确用法:遍历执行操作用forEach arr.forEach(num => console.log(num)); // 1 2(无返回值)

四、常见坑点

  1. 忽略返回值:回调函数必须有return,否则新数组全为undefined
  2. 修改原数组元素(引用类型)map不修改原数组,但如果元素是对象 / 数组(引用类型),修改其属性会改变原数组:

    javascript

    运行

    const users = [{ name: "张三" }]; users.map(user => { user.name = "李四"; // 会修改原数组的user对象! return user; }); console.log(users); // [{ name: "李四" }] // 解决:返回新对象(深/浅拷贝) const newUsers = users.map(user => ({ ...user, name: "李四" }));
  3. 空值处理:若数组元素为null/undefined,回调仍会执行:

    javascript

    运行

    const arr = [1, undefined, 3]; const newArr = arr.map(item => item || 0); console.log(newArr); // [1, 0, 3]

五、总结

list.map()(数组map方法)是前端处理数组的核心工具:

  • 核心用途:数据转换 + 列表渲染
  • 关键原则:纯函数思维,不修改原数组,返回新数组;
  • 避坑要点:回调必须有返回值,引用类型元素需拷贝后修改,遍历无返回值用forEach

它是 React/Vue 等框架中列表渲染的 “标配”,也是日常数据处理的高频方法,掌握其用法能大幅提升前端数组处理效率。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 23:25:32

利率高达36%!微博借钱被指严重超出助贷新规标准

在当今金融科技蓬勃发展的背景下&#xff0c;微博借钱作为微博平台旗下的增值服务&#xff0c;本应成为用户便捷获取资金的渠道&#xff0c;然而&#xff0c;其实际运营中暴露出的种种问题&#xff0c;却让众多借款人深陷困境&#xff0c;引发了广泛的负面反响。微博借钱被指综…

作者头像 李华
网站建设 2026/4/23 12:11:50

AI日报 - 2025年12月15日

#本文由AI生成 &#x1f310; 一、【行业深度】 1. &#x1f31f; Skywork APP 5.0上线&#xff1a;实现多Agent并行协作&#xff0c;一键生成汇报材料 &#x1f525; 热点聚焦&#xff1a; 国产大模型厂商Skywork正式发布移动端APP 5.0版本&#xff0c;首次在消费级应用中实现…

作者头像 李华
网站建设 2026/4/23 12:10:29

中海达“天空地水工”一体化监测体系,赋能安徽水利数字化变革

为加快推进水利科技创新与应用转化&#xff0c;助力安徽水利高质量发展&#xff0c;近日&#xff0c;由安徽省水利技术转移中心主办的“2025年安徽省水利先进实用技术&#xff08;产品&#xff09;推介会”在合肥顺利召开。本次会议聚焦水利科技成果对接与行业数字化转型。中海…

作者头像 李华
网站建设 2026/4/23 10:44:06

自动驾驶—CARLA仿真(10)tutorial_gbuffer demo

测试用例 PythonAPI/examples/tutorial_gbuffer.py 这是一个 高级传感器数据采集示例&#xff0c;用于&#xff1a; 生成一辆自动驾驶车辆挂载高分辨率 RGB 摄像头同时保存最终渲染图像&#xff08;Final Color&#xff09;和所有 GBuffer 纹理 适用于 计算机视觉研究、神经渲染…

作者头像 李华
网站建设 2026/4/23 10:43:48

揭秘大公开咯!提示工程架构师助力Agentic AI技术创新展翅高飞

揭秘大公开咯&#xff01;提示工程架构师助力Agentic AI技术创新展翅高飞 一、引入与连接&#xff1a;当AI从“工具人”进化为“思考者” 清晨7点&#xff0c;你揉着眼睛拿起手机&#xff0c;对智能助手说&#xff1a;“帮我规划下周去三亚的旅行&#xff0c;要兼顾海边放松和美…

作者头像 李华
网站建设 2026/4/22 15:46:38

哪些Agent工具适合中小企业?从选型到落地,一篇吃透

“去年砸20万上的智能系统&#xff0c;现在成了摆设——技术人员招不来也留不住&#xff0c;后台操作没人会&#xff0c;客户咨询还是得靠人工硬扛。”在近期一场中小企业数字化转型沙龙上&#xff0c;做机械配件的王总一开口&#xff0c;就戳中了满堂老板的痛点。这种“投入打…

作者头像 李华