原生JS forEach()和map()遍历的区别、兼容写法及jQuery $.each、$.map遍历操作


Posted in jQuery onFebruary 27, 2019

本文实例讲述了原生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] = item*10;
})
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 item*10;
})
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代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

jQuery 相关文章推荐
QRCode.js:基于JQuery的生成二维码JS库的使用
Jun 23 jQuery
jQuery修改DOM结构_动力节点Java学院整理
Jul 05 jQuery
jQuery之动画ajax事件(实例讲解)
Jul 18 jQuery
简单实现jquery隔行变色
Nov 09 jQuery
基于jquery的on和click的区别详解
Jan 15 jQuery
JQuery扩展对象方法操作示例
Aug 21 jQuery
jQuery轻量级表单模型验证插件
Oct 15 jQuery
jQuery+PHP实现上传裁剪图片
Jun 29 jQuery
JQueryDOM之样式操作
Mar 27 jQuery
使用jquery-easyui的布局layout写后台管理页面的代码详解
Jun 19 jQuery
jquery实现的放大镜效果示例
Feb 24 jQuery
使用jquery实现轮播图效果
Jan 02 jQuery
js/jquery遍历对象和数组的方法分析【forEach,map与each方法】
Feb 27 #jQuery
jQuery表单元素过滤选择器用法实例分析
Feb 20 #jQuery
jQuery内容过滤选择器与子元素过滤选择器用法实例分析
Feb 20 #jQuery
jQuery选择器之基本过滤选择器用法实例分析
Feb 19 #jQuery
jQuery选择器之层次选择器用法实例分析
Feb 19 #jQuery
jQuery选择器之基本选择器用法实例分析
Feb 19 #jQuery
jQuery实现为table表格动态添加或删除tr功能示例
Feb 19 #jQuery
You might like
php框架Phpbean说明
2008/01/10 PHP
php cookie 作用范围?不要在当前页面使用你的cookie
2009/03/24 PHP
PHP的substr_replace将指定两位置之间的字符替换为*号
2011/05/04 PHP
php实现12306余票查询、价格查询示例
2014/04/17 PHP
Laravel 6.2 中添加了可调用容器对象的方法
2019/10/22 PHP
PHP实现一个按钮点击上传多个图片操作示例
2020/01/23 PHP
关于Jquery操作Cookie取值错误的解决方法
2013/08/26 Javascript
javascript中的变量作用域以及变量提升详细介绍
2013/10/24 Javascript
Shell脚本实现Linux系统和进程资源监控
2015/03/05 Javascript
jQuery获得子元素个数的方法
2015/04/14 Javascript
JS实现文字掉落效果的方法
2015/05/06 Javascript
JS组件Bootstrap导航条使用方法详解
2016/04/29 Javascript
浅谈javascript基础之客户端事件驱动
2016/06/10 Javascript
JS实现环形进度条(从0到100%)效果
2016/07/05 Javascript
JS/jQuery判断DOM节点是否存在的简单方法
2016/11/24 Javascript
浅谈js中function的参数默认值
2017/02/20 Javascript
Node.js创建HTTP文件服务器的使用示例
2018/05/11 Javascript
vue--vuex详解
2019/04/15 Javascript
通过实例解析js简易模块加载器
2019/06/17 Javascript
解决vue cli使用typescript后打包巨慢的问题
2019/09/30 Javascript
《javascript设计模式》学习笔记三:Javascript面向对象程序设计单例模式原理与实现方法分析
2020/04/07 Javascript
vant-ui AddressEdit地址编辑和van-area的用法说明
2020/11/03 Javascript
python 自动去除空行的实例
2018/07/24 Python
pygame游戏之旅 调用按钮实现游戏开始功能
2018/11/21 Python
解决pyinstaller打包发布后的exe文件打开控制台闪退的问题
2019/06/21 Python
pytorch实现建立自己的数据集(以mnist为例)
2020/01/18 Python
Python内置函数locals和globals对比
2020/04/28 Python
python的setattr函数实例用法
2020/12/16 Python
俄罗斯香水和化妆品在线商店:Aroma-butik
2020/02/28 全球购物
Juice Beauty官网:有机美容产品,护肤与化妆品
2020/06/13 全球购物
室内设计专业个人的自我评价
2013/12/18 职场文书
文明礼仪小标兵事迹
2014/01/12 职场文书
社区创先争优承诺书
2014/08/30 职场文书
2014年医德医风工作总结
2014/11/13 职场文书
七一晚会主持词
2015/06/29 职场文书
新手初学Java List 接口
2021/07/07 Java/Android