关于[JS] forEach循环return无法跳出的踩坑和解决方案

JavaScript015

关于[JS] forEach循环return无法跳出的踩坑和解决方案,第1张

在leetcode上刷题的时候踩的坑,题目是这样的

简单思考了一下,用最简单的双循环就可以解决问题,于是习惯性用forEach遍历了两次

结果发现函数返回值是undefined

百度了一下,发现是因为forEach多次执行回调函数,回调函数中使用return没法直接终止forEach,只能终止单次的回调。所以return语句在forEach内部是无法跳出循环的。

解决方案:

1.方案一:js针对数组操作的另外两个方法some()与every()

2.方案二:for/while语句老实循环

总结原因还是对forEach方法理解不够到位

1. break结束循环推荐使用

2. return 直接跳出方法,如果仅仅只想结束循环不建议使用,因其副作用是,这个方法不再执行

3. 循环变量=最大值/最小值(看你循环是从高数字到低还是低到高,高到低设置成0,低到高设置成数组的length,该方法对for in语句无效)

//循环变量低到高

var arr=[1,2,3,4,5,6,7]

for(var i=0i<arr.lengthi++)

{

  if(arr[i]==4)

   {

     //break//方案1

     //return//方法后续代码不执行 方案2

     i=arr.length//方案3

   }

}

 

//循环变量从高到低

var arr=[1,2,3,4,5,6,7]

for(var i=arr.length-1i>-1i--)

{

  if(arr[i]==4)

   {

     //break//方案1

     //return//方法后续代码不执行 方案2

     i=-1//方案3

   }

}

 

//for in情况

//循环变量从高到低

var arr=[1,2,3,4,5,6,7]

for(var i in arr)

{

  if(arr[i]==4)

   {

     break//方案1

     //return//方法后续代码不执行 方案2

      //方案3 对此不起作用

   }

}