JS数组中every()与some()两者迭代方法

来源:互联网 发布:布鲁克林法学院 知乎 编辑:程序博客网 时间:2024/05/29 15:19

every()与some()方法都是JS中数组的迭代方法。every()是对数组中的每一项运行给定函数,如果该函数对每一项返回true,则返回true。some()是对数组中每一项运行指定函数,如果该函数对任一项返回true,则返回true。

    我其实在看完这两个函数的介绍时,心里就在想,这两个会不会像逻辑运算符||和&&一样是短路操作?

运行如下代码便知分晓:

[javascript] view plain copy
  1. <span style="font-family:Courier New;font-size:14px;"><script type="text/javascript">  
  2.   
  3.     var arr = [ 1, 2, 3, 4, 5, 6 ];  
  4.   
  5.     console.log( arr.some( function( item, index, array ){  
  6.         console.log( 'item=' + item + ',index='+index+',array='+array );  
  7.         return item > 3;  
  8.     }));  
  9.   
  10.     console.log( arr.every( function( item, index, array ){  
  11.         console.log( 'item=' + item + ',index='+index+',array='+array );  
  12.         return item > 3;  
  13.     }));  
  14.   
  15. </script></span>  

运行结果如下:



   可以看到,some方法是碰到一个返回true的值时候就返回了,并没有继续往下运行,而every也一样,第一个值就是一个false,所以后面也没有进行下去的必要了,就直接返回结果了。

阅读全文
0 0
原创粉丝点击