JavaScript Array 整顿 - 遍历操纵

这是我的原创文章,原文地点:http://lpgray.me/article/48/

本日谈谈基本,在前端开辟中,Array的基本操纵非常频仍多见,在ES5中有很多Array的新特征,然则关于我等中国的码农,尤其是PC前端狗成天就与IE678打交道,有事没事就套一套jQuery,对原生的Array操纵一定迥殊陌生,我也一样。在口试题中,对Array的操纵也是热点题目,本日我就整顿整顿最经常运用的Array要领。

先说说最经常运用的遍历操纵

分别是:

  1. forEach

  2. every

  3. some

  4. map

  5. filter

以上5个函数吸收的参数都一样,分别是:

  1. fn : function范例,吸收3个参数:1,当前遍历的值;2,当前下标;3,当前的数组对象

  2. thisObj: 可选参数,指定fn函数的实行上下文

Array.prototype.forEach(fn, thisObj)

形貌

此函数就是用来遍历数组的每个元素,然后在回调里举行种种操纵,回调的返回值没有意义。

return

Null

Array.prototype.every(fn, thisObj)

形貌

此函数用来遍历数组的每个元素,回调的返回值有意义,返回false时,数组住手轮回。

return

Boolean, 数组中所有元素是不是悉数满足fn的前提。

Array.prototype.some(fn, thisObj)

形貌

此函数用来遍历数组的每个元素,回调的返回值有意义,返回true时,数组住手轮回。

return

Boolean, 数组中是不是存在满足fn前提的元素。

Array.prototype.map(fn, thisObj)

形貌

此函数遍历数组的每个元素,不会转变原数组,fn回调的返回值会用来天生新数组中的元素。

return

Array,fn中每个返回值都是新数组中的每个元素。

Array.prototype.filter(fn, thisObj)

形貌

此函数用来遍历数组的每个元素,不会转变原数组,fn回调必需返回Boolean范例,示意当前元素是不是满足前提能够被返回。

return

Array,fn中每返回一个值,即会添加到新数组中。

要点:forEach, every, some 三者、mapfilter 二者的区分须要迥殊注意。

题目:一个数组最多能够有多长?

ES5中划定 (http://es5.github.io/#x9.6),数组的长度会运用 toUint32() 转化,即 2^32。

    原文作者:叔叔张
    原文地址: https://segmentfault.com/a/1190000002498756
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞