一、原生js forEach()和map()遍历

共同点:

1.都是循环遍历数组中的每一项。

2.forEach() 和 map() 里面每一次执行匿名函数都支持3个参数:数组中的当前项item,当前项的索引index,原始数组input。

3.匿名函数中的this都是指Window。

4.只能遍历数组。

1.forEach()

没有返回值。

[javascript] view plaincopy
  1. var ary = [12,23,24,42,1];
  2. var res = ary.forEach(function (item,index,input) {
  3. input[index] = item*10;
  4. })
  5. console.log(res);//-->undefined;
  6. console.log(ary);//-->会对原来的数组产生改变;

2.map()

有返回值,可以return 出来。

[javascript] view plaincopy
  1. var ary = [12,23,24,42,1];
  2. var res = ary.map(function (item,index,input) {
  3. return item*10;
  4. })
  5. console.log(res);//-->[120,230,240,420,10];
  6. console.log(ary);//-->[12,23,24,42,1];

兼容写法:

不管是forEach还是map在IE6-8下都不兼容(不兼容的情况下在Array.prototype上没有这两个方法),那么需要我们自己封装一个都兼容的方法,代码如下:

[javascript] view plaincopy
  1. /**
  2. * forEach遍历数组
  3. * @param callback [function] 回调函数;
  4. * @param context [object] 上下文;
  5. */
  6. Array.prototype.myForEach = function myForEach(callback,context){
  7. context = context || window;
  8. if('forEach' in Array.prototye) {
  9. this.forEach(callback,context);
  10. return;
  11. }
  12. //IE6-8下自己编写回调函数执行的逻辑
  13. for(var i = 0,len = this.length; i < len;i++) {
  14. callback && callback.call(context,this[i],i,this);
  15. }
  16. }
[javascript] view plaincopy
  1. /**
  2. * map遍历数组
  3. * @param callback [function] 回调函数;
  4. * @param context [object] 上下文;
  5. */
  6. Array.prototype.myMap = function myMap(callback,context){
  7. context = context || window;
  8. if('map' in Array.prototye) {
  9. return this.map(callback,context);
  10. }
  11. //IE6-8下自己编写回调函数执行的逻辑
  12. var newAry = [];
  13. for(var i = 0,len = this.length; i < len;i++) {
  14. if(typeof  callback === 'function') {
  15. var val = callback.call(context,this[i],i,this);
  16. newAry[newAry.length] = val;
  17. }
  18. }
  19. return newAry;
  20. }

二、jQuery $.each()和$.map()遍历

共同点:

即可遍历数组,又可遍历对象。

1.$.each()

没有返回值。$.each()里面的匿名函数支持2个参数:当前项的索引i,数组中的当前项n。如果遍历的是对象,k 是键,n 是值。

[javascript] view plaincopy
  1. $.each( ["a","b","c"], function(i, n){
  2. alert( i + ": " + n );
  3. });
[javascript] view plaincopy
  1. $("span").each(function(i, n){
  2. alert( i + ": " + n );
  3. });
[javascript] view plaincopy
  1. $.each( { name: "John", lang: "JS" }, function(k, n){
  2. alert( "Name: " + k + ", Value: " + n );
  3. });

2.$.map()

有返回值,可以return 出来。$.map()里面的匿名函数支持2个参数和$.each()里的参数位置相反:数组中的当前项n,当前项的索引i。如果遍历的是对象,i 是值,n 是键。如果是$("span").map()形式,参数顺序和$.each()  $("span").each()一样。

[javascript] view plaincopy
  1. var arr=$.map( [0,1,2], function(n){
  2. return n + 4;
  3. });
  4. console.log(arr);
[javascript] view plaincopy
  1. $.map({"name":"Jim","age":17},function(i,n){
  2. console.log(i+":"+n);
  3. });

文章来自 http://blog.csdn.net/huangpb123/article/details/52756303

转载于:https://www.cnblogs.com/aqigogogo/p/7478510.html

forEach与map相关推荐

  1. [JS] for-each和map()的区别

    先说下for-each与for-of还有for-in的区别. for-of和for-in都是对对象操作的,而for-each和map()是对数组进行操作的. for-in的使用:对于一个数组里的每一个 ...

  2. JavaScript中的数组遍历forEach()与map()方法以及兼容写法

    原理: 高级浏览器支持forEach方法 语法:forEach和map都支持2个参数:一个是回调函数(item,index,list)和上下文: forEach:用来遍历数组中的每一项:这个方法执行是 ...

  3. map语法获取index_JavaScript中的数组遍历forEach()与map()方法以及兼容写法

    原理: 高级浏览器支持forEach方法 语法:forEach和map都支持2个参数:一个是回调函数(item,index,list)和上下文: forEach:用来遍历数组中的每一项:这个方法执行是 ...

  4. 原生JS forEach()和map()遍历的区别以及兼容写法

    一.原生JS forEach()和map()遍历 共同点: 1.都是循环遍历数组中的每一项. 2.forEach() 和 map() 里面每一次执行匿名函数都支持3个参数:数组中的当前项item,当前 ...

  5. JS数组中 forEach() 和 map() 的区别

    JS数组中 forEach() 和 map() 的区别 Array中 Array.forEach()和 Array.map()方法之间的区别. forEach()和map()方法通常用于遍历Array ...

  6. forEach、map、filter、some、every、find之间的区别

    前言: 从一开始学了javascript中的for循环遍历方法,到后来了解到forEach.vue中的v-for.map等方法,经常会搞不清楚其中的区别,今天就来粗略的解释一下, for循环我就不说了 ...

  7. JS forEach()与map() 用法(转载)

    JavaScript中的数组遍历forEach()与map()方法以及兼容写法 原理: 高级浏览器支持forEach方法 语法:forEach和map都支持2个参数:一个是回调函数(item,inde ...

  8. Struts2.3,s:iterator,c:forEach遍历map中的list集合

    一:首先是<s:iterator></s:iterator>遍历map中的list集合,代码如下: 1.首先是后台代码,包括定义map和给map中赋值,代码如下: packag ...

  9. 数组中的forEach和map的区别

    大多数情况下,我们都要对数组进行遍历,然后经常用到的两个方法就是forEach和map方法. 先来说说它们的共同点 相同点 都是循环遍历数组中的每一项 forEach和map方法里每次执行匿名函数都支 ...

  10. JS的forEach和map方法的区别

    一.前言 forEach()和map()两个方法都是ECMA5中Array引进的新方法,主要作用是对数组的每个元素执行一次提供的函数,但是它们之间还是有区别的.jQuery也有一个方法$.each() ...

最新文章

  1. Windows 7环境下安装PHP 5.2.17
  2. opencv图像操作:读取,裁剪,保存,缩放,遍历和读取文件夹图片
  3. java jdwp如何关闭_蚀-本机方法中的致命错误:JDWP没有初始化传输,jvmtiError = AGENT_ERROR_TRANSPORT_INIT(197)...
  4. python实现tcp通信_Python实现简易TCP通信程序
  5. c#将http调用返回额json中的有关中文的unicode转换为中文
  6. linux查看注册表信息,linux下登录档及其查看方法
  7. 实战:Redis 集群模式(下)
  8. JAX 是 Google 开发的计算机视觉研究
  9. 流媒体协议(二):RTMP协议
  10. VUE引入JsBarcode组件异常记录
  11. MongoDB Could not find host matching read preference { mode: \primary\ } for set repl_shard1
  12. Jquery 模板插件 jquery.tmpl.js 的使用方法(1):基本语法,绑定,each循环,ajax获取json数据...
  13. 怎么在线把图片转成PDF?几个步骤轻松转换
  14. freeswitch如何判断挂机方
  15. 一帘心事碎碎念,一眸雪舞剪剪风
  16. 有哪些支持C4D的渲染农场
  17. Mysql - 对所有员工的薪水按照salary进行按照1-N的排名
  18. 函数的参数(形参与实参)的理解
  19. JS作用域 , 作用域链
  20. mysql update mapper_mybatis批量update(mysql)

热门文章

  1. C# 中的 gdi 而不是 gdi+
  2. BZOJ 1007 水平可见直线
  3. SQL Serever学习4
  4. 自己设计的一个打字平台
  5. jquery templates jQuery html模板
  6. ios 友盟第三方登录遇到的各种坑。
  7. 面向车、路、城,华人运通“智路”示范项目开通试运行
  8. 【对讲机的那点事】对讲机天馈系统关键元器件之功分器
  9. 【网络编程】网络协议简析
  10. Oracle 中运用rollup和cube实现汇总运算