数组的map与forEach方法

forEach

forEach语句形式,如:

var arr[1,2,3,4,5,6];
arr forEach(function(数组中的元素,每个元素对应的下标,数组自身){

})
arr forEach(function(a,b,c){
		console.log(a,b,c)
})

为更好的加深理解,例题奉上:
例1:求数组中所有元素的和:

var arr=[1,2,3,5,6,7,8,9];
var sum=0;
for(var i=0;i<arr.length;i++){
sum+=arr[i];
}
console.log(sum);

例2:求数组中所有元素的和:

var arr=[2,,6,,8,3,2];
var arr1=[];
arr.forEach(function(item,index){
arr1=[index]=item;
})
console.log(arr1);
//注:使用forEach可以跳过空元素

注:forEach没有返回值,使用return返回无效

Map

map:会返回一个与元素组长度相等的新数组
map语句形式,如:

var arr[1,2,3,4,5,6];
arr forEach(function(数组中的元素,每个元素对应的下标,数组自身){

})
arr forEach(function(item,index,arr){
		console.log(item,index,arr)
})

例1:

var arr=[3,5,7,9,1,2,4];
var arr2=arr.map(function(item,index,arr){
console.log(item,index,arr);
return "a";  //在map中使用return就是在对应的下标中添加对应的数据;
return item+10;
});
console.log(arr2);

例2:

var arr=[1,3,5,7,2,4,6,8];
var arr1=arr.map(function(item){
if(item>4){
return item;
}
});
console.log(arr1);

商品案例:

<script>
var arr=[
            {id:1001,name:"电视",price:4500},
            {id:1002,name:"电脑",price:6500},
            {id:1003,name:"冰箱",price:2000},
            {id:1004,name:"洗衣机",price:1000},
            {id:1005,name:"手机",price:5500}
        ];
        
        arr.forEach(function(item){
            item.num=parseInt(Math.random()*9+1);
            item.total=item.price*item.num;
        })
        console.log(arr); */
    	var arr1=arr.map(function(item){
            item.num=parseInt(Math.random()*9+1);
            item.total=item.price*item.num;
            return item;
        })
        console.log(arr1,arr); 

        // 不改变原数组,完成一个新数组,里面有num和总价

        var arr1=arr.map(function(item){
            var o={};
            for(var prop in item){
                o[prop]=item[prop];
            }
            o.num=parseInt(Math.random()*9+1);
            o.total=o.price*o.num;
            return o;
        })

        console.log(arr1,arr); 
        </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值