停止使用For循环来迭代数组,这里有更好的方法

JavaScript/前端
326
0
0
2022-04-02
全文共1979字,预计学习时长6分钟

停止使用For循环来迭代数组,这里有更好的方法图源:Unsplash

For循环语句是把双刃剑。

它在我心中占有特殊的位置。

长期以来,我一直依赖它来摆脱while循环。

然而不可避免地,这会导致我忘记增加计数器变量。使用for循环来迭代数组的标准语法已经深深印入脑海:For i = 0,i < length,i++…

在教授编程时,我总是用已知迭代次数时使用for循环来区分while和for循环。其原因在于所有的循环语法都是预置好的——这样可以减少错误(尤其是对初学者而言),并使得在六个月后重新查看代码时可以更轻松地浏览。

在编写JavaScript代码时,我已开始远离了钟爱的迭代结构,转而使用.forEach()方法,你也应该这样做。与公式化的for循环相比,.forEach()方法进一步减少了开销,甚至能更清晰地传递代码的意图。这是因为方法的名称总是出现在描述块(block)的口述句中:对于数组中的每个元素,执行某些操作。

停止使用For循环来迭代数组,这里有更好的方法图源:Unsplash

什么是.forEach()方法?

.forEach()作为数组类的内置方法被引入ECMAScript 2015(也称作ES6)。

根据Mozilla文档,该方法将回调作为参数。简单地说,回调是会对数组中的每个元素执行的函数。当需要对每个元素执行相同操作(该操作适合用函数实现)时,使用.forEach()是最适合的。该函数有一个必需的参数,即当前值,以及分别用于索引,基本数组和已分配的this值的三个可选参数。

一个基本示例

为了演示.forEach()方法的基本用法,定义一个整数数组并将每个值的平方打印到控制台。

let nums= [1,2,3,4,5];nums.forEach(function(n) {

console.log(n ** 2); // 1, 4, 9, 16,25

});

包含索引

如果还想输出索引值该怎么办呢?可以在函数定义中包含第二个可选参数。

let nums= [1,2,3,4,5];nums.forEach(function(n,i) {

console.log("i: " + n ** 2);

});

/*

0: 1

1: 4

2: 9

3: 16

4: 25

*/

用.forEach()存储值

如果不想输出所有内容,而是将结果存储在新变量中该怎么办呢?

let nums= [1,2,3,4,5];

let result = nums.forEach(function(n) {

return(n ** 2);

});

console.log(result); // undefined

正如上面的代码段所示,.forEach()方法没有返回值。事实上,使用.map()方法才是正确答案。不过,如果一定要通过.forEach()方法实现,可以手动为新数组赋值。

let nums= [1,2,3,4,5];

let result = [];

nums.forEach(function(n) {

result.push(n**2);

});

console.log(result); // [1,4,9,16,25];

压缩回调函数

如果想进一步压缩代码,可以考虑将回调函数替换为箭头函数。

let nums= [1,2,3,4,5];

nums.forEach((n) => {

console.log(n**2);

});

事实上,如果只使用值(没有可选参数),可以不要n两边的括号;如果循环只是单个语句,完全可以不要大括号{}。

let nums= [1,2,3,4,5];nums.forEach(n => console.log(n**2));

停止使用For循环来迭代数组,这里有更好的方法图源:Unsplash

.forEach()有什么缺陷吗?

答案是肯定的,在选择编写代码方式时总需要进行一些权衡。一个潜在的缺点(实际上并不是缺点,只是为了鼓励更好的实践)是,无法像for循环一样修改每个索引中的原始值:

let nums= [1,2,3,4,5];for(let i=0; i<nums.length; i++) {

nums[i] = nums[i] ** 2;

}console.log(nums); // [1,4,9,16,25]

更新:ES6中引入的for ... of循环旨在将.forEach()替换为更简单且具有更高性能的标准。多谢分享此信息的读者,不胜感激!

停止使用For循环来迭代数组,这里有更好的方法

留言点赞关注

我们一起分享AI学习与发展的干货

如转载,请后台留言,遵守转载规范