【JavaScript】 forEach陷阱

前言:forEach没有返回值!!!设置了返回值也没有返回值。

 

一、for循环的对比

var arr = [1,2,3,4,5];

function test(){
	for(var i =0; i<arr.length; i++){	
		if(arr[i]== 3){
			return '找到3了,并终止了循环';
		}	
		console.log(arr[i]);
	}
}
test();

运行结果:输出了1,2。 并且终止了循环。没有继续输出后面的4,5;

②、console.log(test());

var arr = [1,2,3,4,5];

function test(){
	for(var i =0; i<arr.length; i++){	
		if(arr[i]== 3){
			return '找到3了,并终止了循环';
		}	
		console.log(arr[i]);
	}
}
console.log(test());

运行结果:输出了1,2,'找到3了,并终止了循环'。输出了return 的返回值。

 

二、forEach循环的对比

var arr = [1,2,3,4,5];
function test2(){
	arr.forEach(function(item){
	   if(item == 3) {
		   return '找到3了,并跳过了本次循环';
	   }
	   console.log(item);
	});	
}
test2();

运行结果:输出了1,2,4,5。 并没有终止循环,而是当item==3的时候,跳出了本次循环

②、console.log(test2());

var arr = [1,2,3,4,5];
function test2(){
	arr.forEach(function(item){
	   if(item == 3) {
		   return '找到3了,并跳过了本次循环';
	   }
	   console.log(item);
	});	
}
console.log(test2());

运行结果:输出了1,2,4,5,undefined。 并没有输出我们需要的结果,而是返回了一个undefined。

 

 

三、解决方案

Array.some()的应用

var arr = [1,2,3,4,5];
function test3(){
	arr.some(function(item){
	   if(item == 3) {
		   return '找到了3,并终止了循环';
	   }
	   console.log(item);
	});	
}
console.log(test3());

运行结果:输出了1,2,undefined。 终止了循环,但是没有输出我们需要的结果,而是返回了一个undefined。

Array.every()的应用

var arr = [1,2,3,4,5,3];
function test4(){
	arr.every(function(item){
	   if(item == 3) {
		   return false;
	   }else{
		   console.log(item);
		   return true;
	   }
	});	
}
console.log(test4());

运行结果:输出了1,2,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值