ES5为数组对象定义了5个迭代方法(即递归,简单的说就是自己可以调用自己)。

每个方法接收两个参数:要在每一项上运行的函数(接收3个参数:数组项的值,该项在数组中的位置,数组对象本身)和(可选的)运行该函数的作用域对象——影响this的值。

以下是这5个迭代方法的作用:

  every()对数组中的每一项运行给定函数,如果该函数对每一项都返回true,则返回true ;

  filter()对数组中的每一项运行给定函数,返回该函数会返回true的项组成的数组 ;

  forEach()对数组中的每一项运行给定函数,这个方法没有返回值 ;

  map()对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组 ;

  some()对数组中的每一项运行给定函数,如果该函数对任一项返回true,则返回true;

ps:以上方法不会修改数组中包含的值。

  以上方法中,最相似的是every()和some()方法,他们都用于查询数组中的项是否满足某个条件。

  对于every()来说,传入的函数必须每一项都返回true,这个方法才返回true;反之,返回false;

  而some(),只要传入的函数对数组中的项有一项返回true,则返回true;也就是说some()方法返回false()的可能就是传入的和数组中完全对不上号的时候。------其实我看到这里,有没有觉得它和‘与或非’逻辑门很像?理解性的说,every()就是‘与’,some()就是‘或’,这样就好理解多了。

for example:

  var numbers = [1,2,3,4,5,4,3,2,1];

   var everyResult = numbers.every(function(item,index,array){

    return (item>2);

   });

   alert(everyResult);  //false;

   

  var someResult = numbers.some(function(item,index,array){

    return (item>2);

   });

   alert(someResult);   //true;

    以上代码调用了every()和some(),传入的函数只要给定项大于2就会返回true。

    对于every(), 它返回的是 false,因为只有部分数组项符合条件。

    对于 some(),结果就是 true,因为至少有一项是大于 2的。

filter()函数:它利用指定的函数确定是否在返回的数组中包含某一项。------跟jquery中filter()选择器类似,起一个过滤的作用,返回传入项与数组中相匹配的项。

for example:

   var numbers = [1,2,3,4,5,4,3,2,1];   

    var filterResult = numbers.filter(function(item, index, array){ return (item > 2); });   

   alert(filterResult);    //[3,4,5,4,3]

这里,通过调用 filter()方法创建并返回了包含 3、4、5、4、3的数组,因为传入的函数对它们 每一项都返回 true。这个方法对查询符合某些条件的所有数组项非常有用

  

  map()也返回一个数组,而这个数组的每一项都是在原始数组中的对应项上运行传入函数的结果。------可以当作是遍历数组并对数组中的每一项执行所要执行的函数。

例如,可以给数组中的每一项乘以 2,然后返回这些乘积组成的数组,如下所示。

   var numbers = [1,2,3,4,5,4,3,2,1];

   var mapResult = numbers.map(function(item, index, array){ return item * 2; });

   alert(mapResult);    //[2,4,6,8,10,8,6,4,2]

以上代码返回的数组中包含给每个数乘以 2之后的结果。这个方法适合创建包含的项与另一个数组 一一对应的数组。

后一个方法是 forEach(),它只是对数组中的每一项运行传入的函数。这个方法没有返回值, 本质上与使用 for 循环迭代数组一样。来看一个例子。

var numbers = [1,2,3,4,5,4,3,2,1]; 

numbers.forEach(function(item, index, array){ //执行某些操作 });

ps:这些数组方法通过执行不同的操作,可以大大方便处理数组的任务。支持这些迭代方法的浏览器有 IE9+、Firefox 2+、Safari 3+、Opera 9.5+和 Chrome。

      pps:本人js小白一枚,以上仅是本人看书过程中看到的一些东西,也加一些自己理解的方法,若有不对,欢迎指正,谢谢。

js数组之迭代方法的更多相关文章

  1. JS中数组的迭代方法和归并方法

    昨天总结的JavaScript中的数组Array方法 数组的迭代方法 ES5中为数组定义了5个迭代方法.每个方法都要接收两个参数:要在每一项上面运行的函数和(可选的)运行该函数的作用域对象---影响t ...

  2. JavaScript之数组五大迭代方法总结

    ES5定义了五个迭代方法,每个方法都接收两个参数:要在每一项上运行的函数和运行该函数的作用域对象(可选的),作用域对象将影响this的值.传入这些方法中的函数会接收三个参数:数组的项的值.该项在数组中 ...

  3. 一张图看懂JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some

    好吧,竟然不能单发一张图,不够200字啊不够200字! 在<JavaScript高级程序设计>中,分门别类介绍了非常多数组方法,其中迭代方法里面有6种,这6种方法在实际项目有着非常广泛的作 ...

  4. js数组去重的方法(转)

    JS数组去重的几种常见方法 一.简单的去重方法 // 最简单数组去重法 /* * 新建一新数组,遍历传入数组,值不在新数组就push进该新数组中 * IE8以下不支持数组的indexOf方法 * */ ...

  5. js数组定义和方法 (包含ES5新增数组方法)

    数组Array 1. 数组定义 一系列数据的集合成为数组.数组的元素可以为任何类型的数据(包括数组,函数等),每个元素之间用逗号隔开,数组格式:[1,2,3]. 2. 数组创建方式 (1) 字面量方法 ...

  6. js数组高阶方法reduce经典用法代码分享

    以下是个人在工作中收藏总结的一些关于javascript数组方法reduce的相关代码片段,后续遇到其他使用这个函数的场景,将会陆续添加,这里作为备忘. javascript数组那么多方法,为什么我要 ...

  7. js 数组的迭代

    es5新增加的迭代方法(every,filter,forEach,map,some) arr1 = [1,2,3,4,5,6]; 1,every(); every() 方法使用指定函数检测数组中的所有 ...

  8. js数组的各种方法

    1.检测数组 ①Instanceof: if(value instanceof Array){ } 它假定只有一个全局执行环境,若网页中包含多个框架,则存在多个不同的全局执行环境,则Instanceo ...

  9. JavaScript中数组的迭代方法:forEach、map、filter、reduce、every、some、for in、for of

    JavaScript中有非常多数组迭代方法,这里基本上吧所有的都介绍全了,我项目中比较喜欢的是forEach. 7.for in (for-in循环实际是为循环对象而设计的,for in也可以循环数组 ...

随机推荐

  1. http协议--笔记

    HTTP协议的缺点:1.通信使用明文(不加密),内容可能会被窃听2.不验证通信方的身份,因此有可能遭遇伪装3.无法证明报文的完整性,所以有可能已遭篡改 防止窃听保护信息的几种对策:加密技术通信的加密H ...

  2. 简单实现contentOS下开机自动启动tomcat

    看过网上很多写tomcat开机自启动的例子,很多都是写了一个比较复杂的脚步.找到一个比较简单的. 首先编辑 vi /etc/rc.d/rc.local 在尾部加入 export JDK_HOME=/u ...

  3. springMVC的拦截器工作流程

    首先,springmvc的拦截器配置在这就不多说了.主要讲一下拦截器的三个方法的执行顺序. preHandle方法一定是最先执行的方法,如果它返回为false下面的方法均不执行. postHandle ...

  4. Sublime Text 最佳插件列表

    http://blog.jobbole.com/79326/ 推荐!Sublime Text 最佳插件列表 2014/07/25 · 工具与资源 · 26.1K 阅读 · 2 评论 · Sublime ...

  5. JSP内置对象--out对象(了解即可)

    out对象是javax.servlet.jsp.JspWriter类的实例化对象,主要功能就是完成页面的输出操作,使用println()或print()输出.但是使用纪律很少,都会使用表达式完成输出的 ...

  6. java+tomcat+Eclipse+mysql配置

    Java下载及配置: 1. 下载:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html ...

  7. Eclipse配置

    下载地址:http://www.eclipse.org/downloads/ tomcat plugin:http://www.eclipsetotale.com/tomcatPlugin.html# ...

  8. 使用cisco SDM管理路由器

    实验拓扑: 实验目的:掌握如何通过SDM对路由器进行管理 实验需求:设置R1使其能够通过SDM进行管理 实验步骤: 步骤一:配置基本IP地址 步骤二:在R1上进行设置,使其能够通过SDM连接 R1(c ...

  9. Cisco设备IOS的恢复方法 两种方法

    如果不小心把Router或者Switch的IOS删除了,特别是Flash中的IOS和ROM中的Mini IOS都没有了的话,连启动都不行的话,有什么方法恢复它呢?答案是方法不只一种,而是两种.其实是我 ...

  10. 手机电话号码吉凶查询原理及ASP算法源码 转

    随着手机的快速普及,越来越多的人都在使用手机,而号码的挑选也是用户越来越关心的事情.虽然号码只是个代号而已,但几千年的传统积淀仍给号码赋予其各种含义,至于号码的吉凶也是见仁见智的一种个人喜好问题,或许 ...