返回

#yyds干货盘点#JS中的map用法

发布时间:2022-10-25 19:18:58 272

map()

​map()​​ 方法会返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。

​map​​​ 方法会给原数组中的每个元素都按顺序调用一次 ​​callback​​​ 函数。​​callback​​​ 每次执行后的返回值(包括 ​​undefined​​​)组合起来形成一个新数组。 ​​callback​​​ 函数只会在有值的索引上被调用;那些从来没被赋过值或者使用 ​​delete​​ 删除的索引则不会被调用。

因为​​map​​生成一个新数组,当你不打算使用返回的新数组却使用​​map​​是违背设计初衷的,请用​​forEach​​或者​​for-of​​替代。你不该使用​​map​​: A)你不打算使用返回的新数组,或/且 B) 你没有从回调函数中返回值。

​callback​​ 函数会被自动传入三个参数:数组元素,元素索引,原数组本身。

var map = Array.prototype.map
var a = map.call("Hello World", function(x) {
return x.charCodeAt(0);
})
// a的值为[72, 101, 108, 108, 111, 32, 87, 111, 114, 108, 100]

可以链式调用

arr.map(item=>item.time).map(item=>item.scaner)

注意点:

  • map 方法不会对空数组进行检测;
  • map 方法遍历数组时会返回一个新数组,不会改变原始数组
  • map 方法有返回值,可以return出来,map的回调函数中支持return返回值;
  • map 方法无法遍历对象,仅适用于数组的遍历。
  • ​map​​​ 方法处理数组元素的范围是在​​callback​​​ 方法第一次调用之前就已经确定了。调用​​map​​​方法之后追加的数组元素不会被​​callback​​​访问。如果存在的数组元素改变了,那么传给​​callback​​​的值是​​map​​​访问该元素时的值。在​​map​​函数调用后但在访问该元素前,该元素被删除的话,则无法被访问到。


场景实例

使用 map 重新格式化数组中的对象

var kvArray = [{key: 1, value: 10},
{key: 2, value: 20},
{key: 3, value: 30}];

var reformattedArray = kvArray.map(function(obj) {
var rObj = {};
rObj[obj.key] = obj.value;
return rObj;
});

// reformattedArray 数组为: [{1: 10}, {2: 20}, {3: 30}],
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像
精选文章
thumb 中国研究员首次曝光美国国安局顶级后门—“方程式组织”
thumb 俄乌线上战争,网络攻击弥漫着数字硝烟
thumb 从网络安全角度了解俄罗斯入侵乌克兰的相关事件时间线
下一篇
浏览器唤醒 app 解决方案汇总 2022-10-25 18:57:50