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

放大字体  缩小字体 发布日期:2019-12-21  来源:来自互联网  作者:来自互联网  浏览次数:936
导读

当需要对每个元素执行相同操作(该操作适合用函数实现)时,使用.forEach()是最适合的。该函数有一个必需的参数,即当前值,以及分别用于索引,基本数组和已分配的this值的三个可选参数。 事实上,如果只…

全文共1979字,预计学习时长6分钟

全文共1979字,预计学习时长6分钟

图源:Unsplash

For循环语句是把双刃剑。

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

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

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

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

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

图源: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);});

用.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));

图源: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()替换为更简单且具有更高性能的标准。多谢分享此信息的读者,不胜感激!

留言 点赞 关注

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

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

 
 
免责声明
• 
本文为会员免费发布,仅代表发布者个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,作者需自行承担相应责任。涉及到版权或其他问题,请及时联系我们删除处理。