<!DOCTYPE html>
<html>
<head>
<title>模拟Array中的forEach()方法</title>
</head>
<body>
<script type="text/javascript">
/*
// ECMA中 forEach(); 循环遍历数组中的每一项,只适合一维数组
var arr = [1,2,3,[4,[5]]];
arr.forEach(function(item) {
alert(item);
});// 1 2 3 4,5
*/
// 自己实现forEach(), 且能遍历多维
var arr = [1,2,3,[4,[5,[6]]]];
Array.prototype.each = function(fn){
try{
// 1.目的:遍历一个数组,需要一个计数器,指向当前遍历的元素位置
this.i || (this.i = 0);
// 2. 严谨的判断什么时候进入each的核心方法
// 当数组长度大于0 的时候 且 传递的参数必须为函数
if(this.length > 0 && fn.constructor == Function) {
// 遍历循环数组的每一项
while(this.i < this.length) {
// 获取数组的每一项
var e = this[this.i];
// 如果当前元素获取了,且当前元素是一个数组
if(e && e.constructor == Array){
// 直接做递归的操作
e.each(fn);
} else {
// 如果不是数组,就是单个元素
// 则将元素作为实参传递给fn,执行fn函数
fn.apply(e,[e]);
}
this.i++;
}
this.i = null; // 释放内存,垃圾回收机制
}
} catch(ex){
//do something
}
return this;
};
arr.each(function(item) {
alert(item);
})
</script>
</body>
</html>
<html>
<head>
<title>模拟Array中的forEach()方法</title>
</head>
<body>
<script type="text/javascript">
/*
// ECMA中 forEach(); 循环遍历数组中的每一项,只适合一维数组
var arr = [1,2,3,[4,[5]]];
arr.forEach(function(item) {
alert(item);
});// 1 2 3 4,5
*/
// 自己实现forEach(), 且能遍历多维
var arr = [1,2,3,[4,[5,[6]]]];
Array.prototype.each = function(fn){
try{
// 1.目的:遍历一个数组,需要一个计数器,指向当前遍历的元素位置
this.i || (this.i = 0);
// 2. 严谨的判断什么时候进入each的核心方法
// 当数组长度大于0 的时候 且 传递的参数必须为函数
if(this.length > 0 && fn.constructor == Function) {
// 遍历循环数组的每一项
while(this.i < this.length) {
// 获取数组的每一项
var e = this[this.i];
// 如果当前元素获取了,且当前元素是一个数组
if(e && e.constructor == Array){
// 直接做递归的操作
e.each(fn);
} else {
// 如果不是数组,就是单个元素
// 则将元素作为实参传递给fn,执行fn函数
fn.apply(e,[e]);
}
this.i++;
}
this.i = null; // 释放内存,垃圾回收机制
}
} catch(ex){
//do something
}
return this;
};
arr.each(function(item) {
alert(item);
})
</script>
</body>
</html>