数组方法map的使用及与forEach的比较


prtyaa
prtyaa 2023-12-25 16:23:02 66054
分类专栏: 资讯

先来看一下对数组map()方法的定义:map() 方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。

大家要注意map在这里并不是地图的意思,确切的解释应该是映射!也就是说通过该方法你可以经过一些自己的逻辑处理,映射出来一个新的数组,而对原数组没有影响。

先来看一个示例,对arr的元素值乘以2,并生成一个新的数组newArr:

var arr=[1,3,4,5,7,9];
var newArr=arr.map((v)=>{
    return v*2;
})
//newArr为arr元素值的2倍
console.log(newArr);//[ 2, 6, 8, 10, 14, 18 ]
//arr的值并没有发生变化
console.log(arr);//[ 1, 3, 4, 5, 7, 9 ]

如果你要你想对奇数乘以2的话,你可以这样:

var arr=[1,3,4,5,7,9];
var newArr=arr.map((v)=>{
    if(v%2==1)
        return v*2;
    return v;
})
//newArr中只有元素值为4的偶数没有发生变化
console.log(newArr);//[ 2, 6, 4, 10, 14, 18 ]
//arr的值并没有发生变化
console.log(arr);//[ 1, 3, 4, 5, 7, 9 ]

map方法中的回调必须要有返回值,否则会被映射为undefined:

var arr=[1,3];
var newArr=arr.map((v)=>{})
// 没有return 映射出来的值为undefined
console.log(newArr);//[ undefined, undefined ]
// arr的值并没有发生变化
console.log(arr);//[ 1, 3 ]

在实际使用中,咱们一般都会通过该方法取到原数组中的一些特定值,比如:

var arr=[
    {
        userName:"xiaozhang",
        phoneNum:"151098765**"
    },{
        userName:"laowang",
        phoneNum:"158984736**"
    }
];
var phoneArr=arr.map((item)=>{
    //只提取其中的手机号码
    return item.phoneNum
});
console.log(phoneArr);//[ '151098765**', '158984736**' ]

map方法与forEach使用起来类似:都是循环遍历数组中的每一项;每次执行匿名函数都支持3个参数,参数分别是item(当前每一项)、index(索引值)、arr(原数组);匿名函数中的this都是指向window:都只支持数组。

不同点在于forEach运行后的返回值为undefined。并不像map方法一样会映射一个新的数组:

var arr=[1,3,4,5,7,9];
var newArr=arr.forEach((v)=>{
    return v*2;
})
//undefined
console.log(newArr);//undefined
//arr的值并没有发生变化
console.log(arr);//[ 1, 3, 4, 5, 7, 9 ]

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=30615
赞同 0
评论 0 条
prtyaaL0
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1325
银河麒麟打印带有图像的文档时出错  1238
银河麒麟添加打印机时,出现“server-error-internal-error”  1025
统信桌面专业版【如何查询系统安装时间】  953
统信操作系统各版本介绍  946
统信桌面专业版【全盘安装UOS系统】介绍  905
麒麟系统也能完整体验微信啦!  892
统信【启动盘制作工具】使用介绍  501
统信桌面专业版【一个U盘做多个系统启动盘】的方法  443
信刻全自动档案蓝光光盘检测一体机  389
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!