JS数组遍历方法这么多,for/forEach/forof我该怎么选?

在 JavaScript 里,forEachforfor...of 循环都能用来遍历数组,不过适用场景存在差异,下面为你详细分析:

1. for 循环

这是一种较为基础的循环结构,它的优势在于能够灵活控制循环的起始、结束条件以及步长。

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
for (let i = 0; i < numbers.length; i++) {
    console.log(numbers[i]);
}

适用场景 :当你需要精确控制循环的索引,比如在循环中对索引进行一些运算,或者需要反向遍历数组时,for 循环是不错的选择。

2. forEach 方法

forEach 是数组的一个方法,它会为数组的每个元素执行一次提供的函数。

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(number) {
    console.log(number);
});

适用场景 :当你只需要对数组的每个元素执行相同的操作,且不需要中途跳出循环时,forEach 方法可以让代码更加简洁易读。不过,forEach 不能使用 breakcontinue 语句来控制循环流程。

3. for...of 循环

for...of 循环可以遍历可迭代对象,包括数组、字符串、Set、Map 等。

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
for (const number of numbers) {
    console.log(number);
}

适用场景 :当你只关心数组元素的值,而不关心索引,并且需要使用 breakcontinue 语句来控制循环流程时,for...of 循环是比较合适的选择。

总结

  • 若要精确控制索引,或需要反向遍历数组,推荐使用 for 循环。
  • 若仅需对数组元素执行相同操作,且无需中途跳出循环,使用 forEach 方法会让代码更简洁。
  • 若只关注元素值,且需要使用 breakcontinue 控制循环,建议使用 for...of 循环。

如果都可以的场景,优先推荐哪一种?

在各种循环方式都适用的场景下,优先推荐使用 for...of 循环,以下是具体原因:

1. 代码简洁性与可读性

和传统的 for 循环相比,for...of 循环不需要手动管理索引变量,代码结构更加简洁。它能让阅读代码的人迅速理解你只是想逐个访问数组里的元素。例如:

javascript 复制代码
const arr = [10, 20, 30];

// 使用 for...of 循环
for (const num of arr) {
    console.log(num);
}

// 使用传统 for 循环
for (let i = 0; i < arr.length; i++) {
    console.log(arr[i]);
}

可以看到,for...of 循环的代码更加简洁直观。

2. 灵活性

for...of 循环允许使用 breakcontinue 语句,这使得在循环过程中可以根据特定条件灵活控制循环流程,而 forEach 方法无法使用这些语句。例如,当遇到特定元素时跳出循环:

javascript 复制代码
const arr = [10, 20, 30, 40, 50];
for (const num of arr) {
    if (num === 30) {
        break;
    }
    console.log(num);
}

3. 可迭代对象的通用性

for...of 循环不仅能用于数组,还能用于其他可迭代对象,像字符串、Set、Map 等。这意味着在处理不同类型的可迭代数据时,你可以使用统一的循环方式。例如:

javascript 复制代码
// 遍历字符串
const str = 'hello';
for (const char of str) {
    console.log(char);
}

// 遍历 Set
const set = new Set([1, 2, 3]);
for (const value of set) {
    console.log(value);
}

4. 性能表现

在大多数情况下,for...of 循环的性能和传统 for 循环相近,而且比 forEach 方法更好,因为 forEach 方法在调用回调函数时会有额外的函数调用开销。

综上所述,在各种循环方式都适用的场景下,for...of 循环是一个更优的选择。

什么!你用map或reduce?

相关推荐
摘星编程20 分钟前
React Native + OpenHarmony:Timeline垂直时间轴
javascript·react native·react.js
2501_944525541 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
jin1233222 小时前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos
李白你好2 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
经年未远3 小时前
vue3中实现耳机和扬声器切换方案
javascript·学习·vue
刘一说3 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
可触的未来,发芽的智生3 小时前
狂想:为AGI代称造字ta,《第三类智慧存在,神的赐名》
javascript·人工智能·python·神经网络·程序人生
徐同保4 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
fanruitian4 小时前
uniapp 创建项目
javascript·vue.js·uni-app
刘一说4 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js