JavaScript学习之遍历多维数组

JavaScript提供了forEach方法遍历数组,但是只能遍历一维数组。今天学习了一下记录下来

这里有篇博客介绍JavaScript多维数组如何建立很详细  http://blog.csdn.net/wangyuchun_799/article/details/38460515

我自己的写法

var arr = [1,2,3,4,[5],[6,7,[8,9,[10,11]]]];
// arr.forEach(function(item,index,array){
// 	alert(item);
// })
Array.prototype.each = function(fn){
	var tmp = this;
	for (var i = 0, length = tmp.length; i < length; i++) {
		if(tmp[i] && tmp[i].constructor == Array){
			tmp[i].each(fn);
		}else{
			fn.call(tmp[i],tmp[i]);
		}
	}
};
arr.each(function(item){
	alert(item);
})
bhx老师的写法
// Array each方法
					
					// ECMA5 forEach 循环遍历数组的每一项(只适合遍历一维数组)
					/*
					var arr = [1,2,3,4,5];
					arr.forEach(function(item , index , array){
						alert(item);
					});
					*/
					// 自己实现一个Array each方法 能遍历多维数组 
					var arr = [1,2,3,[4,[5,[6]]]]; // arr.length
					
					Array.prototype.each = function(fn){
						try{
							//1 目的: 遍历数组的每一项 //计数器 记录当前遍历的元素位置
							this.i || (this.i=0);  //var i = 0 ;
							//2 严谨的判断什么时候去走each核心方法
							// 当数组的长度大于0的时候 && 传递的参数必须为函数
							if(this.length > 0 && fn.constructor == Function){
								// 循环遍历数组的每一项
								while(this.i < this.length){	//while循环的范围 
									//获取数组的每一项
									var e = this[this.i];
									//如果当前元素获取到了 并且当前元素是一个数组
									if(e && e.constructor == Array){
										// 直接做递归操作
										e.each(fn);
									} else {
										//如果不是数组 (那就是一个单个元素)
										// 这的目的就是为了把数组的当前元素传递给fn函数 并让函数执行
										//fn.apply(e,[e]);
										fn.call(e,e);
									}
									this.i++ ;
								}
								this.i = null ; // 释放内存 垃圾回收机制回收变量
							}
							
						} catch(ex){
							// do something 
						}
						return this ;
					}
					
					arr.each(function(item){
						alert(item);
					});


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值