数组map方法的应用场景及经典面试题

简介: 数组map方法的应用场景及经典面试题

数组map方法的应用场景及经典面试题


map最大的作用:从一个数组得到一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。

上句是核心。

换言之,平时只要有从数组中得到一个新数组的时候,就可以联想下map

大部分情况下,map里的函数传入一个参数就够用。

以下是应用场景,可以的话,先自己实现下

求数组中每个元素的平方

function pow(x) {
  return x * x;
}
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
// [1, 4, 9, 16, 25, 36, 49, 64, 81]
var results = arr.map(pow);

把数组中每个元素变成字符串

var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
// ['1', '2', '3', '4', '5', '6', '7', '8', '9']
var results2 = arr.map(String);

重新格式化数组中的对象

就是数组的每项都是对象,然后进行操作。或者对对象的某个值进行改变。

var kvArray = [
  { key: 1, value: 10 },
  { key: 2, value: 20 },
  { key: 3, value: 30 }
];
// [{1: 10}, {2: 20}, {3: 30}]
var reformattedArray = kvArray.map(function(obj) {
  var rObj = {};
  rObj[obj.key] = obj.value;
  return rObj;
});

map用在离散数组的时候

map遍历的时候,如果当前值是undefined,则直接返回undefined。

// [2,4,,,8]
[1,2,,,4].map(item=>item*2)

字符串也可使用map,生成新的数组

如获取字符串中每个字符所对应的 ASCII 码组成的数组

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]

类数组也可使用map,生成新的数组

比如得到所有选中选项的值,并将其打印:

var ele = document.querySelectorAll("select option:checked");
var values = Array.prototype.map.call(ele, function(obj) {
  return obj.value;
});

map易错的地方 -- 面试常碰到

<!-- res的值 -->
var res = ["1", "2", "3"].map(parseInt);

如果不小心的话,可能会说成 [1,2,3]

考点:map的callback不止一个参数,总共三个参数,cur、index、curIndex。

parseInt可以接受两个参数,所以上面会[1, NaN, NaN],因为第二个参数index被传进去了。改进方法

["1", "2", "3"].map( item => parseInt(item));

``

手写实现map方法

这里官方的更权威,这里只是简单实现大概逻辑

Array.prototype.map = function(fn) {
  let res = [];
  // this指当前的数组
  let curArr = this;
  for (let i = 0; i < curArr.length; i++) {
    let value = curArr[i];
    if (typeof value !== "undefined") {
     let mappedValue = fn(value, i, curArr);
     res[i] = mappedValue;
    }
  }
  return res;
};

引用

此文基本根据文档总结来的,可以细看原文档

mdn 的 map

目录
相关文章
|
7天前
|
消息中间件 测试技术 数据库
吊打面试官!应用间交互如何设计?
【10月更文挑战第18天】设计应用间交互需从明确需求、选择合适方式、设计协议与数据格式、考虑安全性和权限管理、进行性能优化和测试五个方面入手。明确功能和用户需求,选择接口调用、消息队列、数据库共享或文件交换等方式,确保交互高效、安全、可靠。展示这些能力将在面试中脱颖而出。
|
1月前
|
索引
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
ES5常见的数组方法:forEach ,map ,filter ,some ,every ,reduce (除了forEach,其他都有回调,都有return)
|
29天前
|
数据处理 Python
Pandas中的map函数应用
Pandas中的map函数应用
14 2
|
1月前
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
11天前
|
前端开发 JavaScript 索引
JavaScript 数组常用高阶函数总结,包括插入,删除,更新,反转,排序等,如map、splice等
JavaScript数组的常用高阶函数,包括遍历、插入、删除、更新、反转和排序等操作,如map、splice、push、pop、reverse等。
14 0
|
1月前
|
ARouter 测试技术 API
Android经典面试题之组件化原理、优缺点、实现方法?
本文介绍了组件化在Android开发中的应用,详细阐述了其原理、优缺点及实现方式,包括模块化、接口编程、依赖注入、路由机制等内容,并提供了具体代码示例。
35 2
|
2月前
|
Java API 索引
【Java基础面试二十四】、String类有哪些方法?
这篇文章列举了Java中String类的常用方法,如`charAt()`、`substring()`、`split()`、`trim()`、`indexOf()`、`lastIndexOf()`、`startsWith()`、`endsWith()`、`toUpperCase()`、`toLowerCase()`、`replaceFirst()`和`replaceAll()`,并建议面试时展示对这些方法的熟悉度,同时深入理解部分方法的源码实现。
【Java基础面试二十四】、String类有哪些方法?
|
1月前
数组方法中的`forEach()`方法和`map()`方法有什么区别?
数组方法中的`forEach()`方法和`map()`方法有什么区别?
|
1月前
|
JavaScript 前端开发
JavaScript 中 五种迭代数组的方法 every some map filter forEach
本文介绍了JavaScript中五种常用数组迭代方法:every、some、filter、map和forEach,并通过示例代码展示了它们的基本用法和区别。
|
2月前
|
JavaScript 前端开发 索引
JS中常用的数组迭代方法(filter,forEach,map,every,some,find,findIndex)
这段代码和说明介绍了JavaScript中数组的一些常用方法。函数接收三个参数:`item`(数组项的值)、`index`(项的位置,可选)和`array`(数组本身,可选)。示例展示了如何使用`filter()`过滤非空项、`forEach()`遍历数组、`map()`处理并返回新数组、`every()`检查所有元素是否满足条件、`some()`检查是否存在满足条件的元素、`find()`获取首个符合条件的元素值以及`findIndex()`获取其索引位置。这些方法都不会修改原数组。
JS中常用的数组迭代方法(filter,forEach,map,every,some,find,findIndex)