您的位置:首页 > Web前端 > JavaScript

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

2017-06-20 14:05 525 查看
every()与some()方法都是JS中数组的迭代方法。every()是对数组中的每一项运行给定函数,如果该函数对每一项返回true,则返回true。some()是对数组中每一项运行指定函数,如果该函数对任一项返回true,则返回true。

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

运行如下代码便知分晓:

[javascript] view
plain copy

<span style="font-family:Courier New;font-size:14px;"><script type="text/javascript">  

  

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

  

    console.log( arr.some( function( item, index, array ){  

        console.log( 'item=' + item + ',index='+index+',array='+array );  

        return item > 3;  

    }));  

  

    console.log( arr.every( function( item, index, array ){  

        console.log( 'item=' + item + ',index='+index+',array='+array );  

        return item > 3;  

    }));  

  

</script></span>  

运行结果如下:



   可以看到,some方法是碰到一个返回true的值时候就返回了,并没有继续往下运行,而every也一样,第一个值就是一个false,所以后面也没有进行下去的必要了,就直接返回结果了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐