原生JS forEach()和map()遍历的区别、兼容写法及jQ
本文实例讲述了原生JS forEach()和map()遍历的区别、兼容写法及jQuery $.each、$.map遍历操作。分享给大家供大家参考,具体如下
一、原生JS forEach()和map()遍历
共同点
①.都是循环遍历数组中的每一项。
②.forEach()
和 map()
里面每一次执行匿名函数都支持3个参数数组中的当前项item,当前项的索引index,原始数组input。
③.匿名函数中的this都是指Window。
④.只能遍历数组。
1.forEach()
没有返回值。
var ary = [12,23,24,42,1]; var res = ary.forEach(function (item,index,input) { input[index] = item10; }) console.log(res);//-->undefined; console.log(ary);//-->会对原来的数组产生改变
2.map()
有返回值,可以return 出来。
var ary = [12,23,24,42,1]; var res = ary.map(function (item,index,input) { return item10; }) console.log(res);//-->[120,230,240,420,10]; console.log(ary);//-->[12,23,24,42,1]
兼容写法
不管是forEach还是map在IE6-8下都不兼容(不兼容的情况下在Array.prototype
上没有这两个方法),那么需要我们自己封装一个都兼容的方法,代码如下
/ forEach遍历数组 @param callback [function] 回调函数; @param context [object] 上下文; / Array.prototype.myForEach = function myForEach(callback,context){ context = context || window; if('forEach' in Array.prototye) { this.forEach(callback,context); return; } //IE6-8下自己编写回调函数执行的逻辑 for(var i = 0,len = this.length; i < len;i++) { callback && callback.call(context,this[i],i,this); } }
/ map遍历数组 @param callback [function] 回调函数; @param context [object] 上下文; / Array.prototype.myMap = function myMap(callback,context){ context = context || window; if('map' in Array.prototye) { return this.map(callback,context); } //IE6-8下自己编写回调函数执行的逻辑 var newAry = []; for(var i = 0,len = this.length; i < len;i++) { if(typeof callback === 'function') { var val = callback.call(context,this[i],i,this); newAry[newAry.length] = val; } } return newAry; }
二、jQuery $.each()和$.map()遍历
共同点
即可遍历数组,又可遍历对象。
1.$.each()
没有返回值。$.each()
里面的匿名函数支持2个参数当前项的索引i,数组中的当前项n。如果遍历的是对象,k 是键,n 是值。
$.each( ["a","b","c"], function(i, n){ alert( i + ": " + n ); });
$("span").each(function(i, n){ alert( i + ": " + n ); });
$.each( { name: "John", lang: "JS" }, function(k, n){ alert( "Name: " + k + ", Value: " + n ); });
2.$.map()
有返回值,可以return 出来。$.map()
里面的匿名函数支持2个参数和$.each()
里的参数位置相反数组中的当前项n,当前项的索引i。如果遍历的是对象,i 是值,n 是键。如果是$("span").map()
形式,参数顺序和$.each()
$("span").each()
一样。
var arr=$.map( [0,1,2], function(n){ return n + 4; }); console.log(arr);
$.map({"name":"Jim","age":17},function(i,n){ console.log(i+":"+n); });
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具测试上述代码运行效果。
PS这里再为大家推荐一款JS数组遍历方式分析对比工具供大家参考
在线JS常见遍历方式性能分析比较工具
更多关于JavaScript相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》及《》
希望本文所述对大家JavaScript程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程