JavaScript数组遍历无唯一正确方式,需据需求选择:for循环最可控且性能最优,适合需中途跳出或反向遍历;map/filter/find语义精准、易组合;for...of支持await和break/continue,推荐日常使用;遍历前须校验Array.isArray。

JavaScript 数组遍历没有唯一“正确”方式,选哪种取决于你要做什么——改原数组?生成新数组?只查条件?还是需要索引和迭代控制?
用 for 循环遍历最可控
原生 for 是唯一能自由控制起始、终止、步长,且支持 break/continue 提前退出的遍历方式。它不创建新作用域,性能也最直接。
- 适合需要中途跳出(比如找第一个匹配项后就停)、或反向遍历(
for (let i = arr.length - 1; i >= 0; i--)) - 注意别写成
for (let i = 0; i ——会越界访问arr[arr.length],返回undefined - 遍历时修改数组长度(如
push或splice)可能跳过或重复处理元素,要格外小心
forEach 适合纯副作用操作
forEach 语义明确:只用来“对每个元素做点事”,不返回新数组,也不响应 return 或 break。
- 不能用
return中断循环,想提前退出得抛错或改用for - 回调函数中
this默认是undefined(严格模式),传入第二个参数可绑定上下文:arr.forEach(cb, thisArg) - 不支持异步等待:在
forEach(async () => {...})里写await不会按顺序等待,要用for...of或map+Promise.all
map / filter / find 按意图选,别硬套 forEach
这些方法返回新数组或单个值,语义比 forEach 更精准,也更容易组合和测试。
立即学习“Java免费学习笔记(深入)”;
-
map:要转换每个元素(如arr.map(x => x * 2)),返回等长新数组 -
filter:要筛选(如arr.filter(x => x > 0)),返回子集 -
find:只要第一个满足条件的值(arr.find(x => x.id === 123)),找到即停,返回元素本身或undefined - 它们都忽略稀疏数组的空位,而
for和forEach会把空位当作undefined处理
for...of 遍历值,entries() 同时拿索引和值
for...of 是 ES2015 引入的语法糖,底层调用迭代器,语义清晰、支持 break/continue,且天然兼容异步(await 可用)。
- 只遍历值:
for (const item of arr) { ... } - 要索引和值一起?用
arr.entries():for (const [index, value] of arr.entries()) { ... } - 注意:它不能直接遍历类数组(如
arguments或 DOM NodeList),得先转成真数组或用Array.from - 性能略低于
for,但现代引擎优化后差距极小;可读性提升明显,日常开发推荐优先考虑
真正容易被忽略的是:遍历前先确认数组是否为真数组(Array.isArray(arr)),尤其当数据来自 API 或用户输入时——伪数组、null、undefined 或非对象类型传给 map/forEach 会直接报 TypeError: xxx is not a function 或 Cannot read property 'length' of null。











