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());

 

 

二、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());

 

 ②、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()结果和some()结果一样

转自https://blog.csdn.net/w390058785/article/details/79916266

转载于:https://www.cnblogs.com/psxiao/p/11606447.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值