如何用javascript进行数组遍历【教程】

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

如何用javascript进行数组遍历【教程】

JavaScript 数组遍历没有唯一“正确”方式,选哪种取决于你要做什么——改原数组?生成新数组?只查条件?还是需要索引和迭代控制?

for 循环遍历最可控

原生 for 是唯一能自由控制起始、终止、步长,且支持 break/continue 提前退出的遍历方式。它不创建新作用域,性能也最直接。

  • 适合需要中途跳出(比如找第一个匹配项后就停)、或反向遍历(for (let i = arr.length - 1; i >= 0; i--)
  • 注意别写成 for (let i = 0; i ——会越界访问 arr[arr.length],返回 undefined
  • 遍历时修改数组长度(如 pushsplice)可能跳过或重复处理元素,要格外小心

forEach 适合纯副作用操作

forEach 语义明确:只用来“对每个元素做点事”,不返回新数组,也不响应 returnbreak

  • 不能用 return 中断循环,想提前退出得抛错或改用 for
  • 回调函数中 this 默认是 undefined(严格模式),传入第二个参数可绑定上下文:arr.forEach(cb, thisArg)
  • 不支持异步等待:在 forEach(async () => {...}) 里写 await 不会按顺序等待,要用 for...ofmap + 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
  • 它们都忽略稀疏数组的空位,而 forforEach 会把空位当作 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 或用户输入时——伪数组、nullundefined 或非对象类型传给 map/forEach 会直接报 TypeError: xxx is not a functionCannot read property 'length' of null

https://www.php.cn/faq/2020818.html

发表回复

Your email address will not be published. Required fields are marked *