js数组高阶函数——map()方法_js map方法

⭐将一个数组中的对象转换为另一个数组,只保留对象中的某些属性:

const users = [
  {name: 'Alice', age: 25},
  {name: 'Bob', age: 30},
  {name: 'Charlie', age: 35},
];
const names = users.map(function(user) {
  return user.name;
});
console.log(names); // ['Alice', 'Bob', 'Charlie']


⭐将一个数组中的字符串转换为另一个数组,只保留长度大于等于5的字符串:

const words = ['apple', 'banana', 'cherry', 'date', 'elderberry'];
const longWords = words.map(function(word) {
  if (word.length >= 5) {
    return word;
  }
});
console.log(longWords); // ['apple', 'banana', 'cherry', undefined, 'elderberry']


⭐⭐⭐需要注意的是,在使用 map() 方法时,我们可以选择传递可选参数 thisArg 来设置回调函数的 this 值。如果不传递 thisArg 参数,则默认情况下,回调函数的 this 值为undefined

举个例子:

let numbers = [1, 2, 3];
let obj = { multiplier: 2 };
let doubled = numbers.map(function(num) {
    return num \* this.multiplier;
}, obj);
console.log(doubled); // 输出 [2, 4, 6]

上面的例子中,我们定义了一个名为 numbers 的数组,其中包含三个数字。我们还定义了一个名为 obj 的对象,其中包含一个名为 multiplier 的属性,该属性的值为 2。我们在回调函数中使用 this.multiplier,其中 this 值为 obj,来将数组中的每个元素乘以 2。


map()的优缺点

优点:

  • map()默认会有返回值,一般返回一个数组。这里要强调一下,函数默认没有返回值。如果函数内部没有明确使用return语句返回一个值,那么该函数执行完毕后会自动返回undefined。所以这个也是map()的一个特色
  • 可以方便地对数组中的每个元素进行操作,并生成一个新的数组;
  • 不会改变原始数组。

缺点:

  • 无法使用break,continue,return等关键字控制循环,必须全部遍历完毕才能停止;
  • 对于大型数据集合而言,可能会导致性能问题。

数据小的时候,用map()循环非常的爽,不是很消耗性能。但数据大的情况下,用map()会很耗性能,因为map()会对数组中的每个元素执行一次callback方法。建议数据大的时候,用for循环。虽然多次for循环嵌套看着恶心,但是性能好,是底层的东西。而所谓的map(),set(),for in,for of 都是在for循环的基础上再封装。单从性能角度考虑,远不如for循环优秀。

map()的使用场景

  • 将一组数据转换为另一种形式或格式;
  • 对一组数据进行过滤、去重等操作;
  • 对一组DOM元素进行修改等操作;

去重

一般情况下,去重一个数组,有这么几种方法。

双重for循环配合splie去重

//先定义一个数组
var arr=[1,2,2,3,4,4,5]
//双重for循环
for(i = 0;i < arr.length; i++){
  for(j = i+1;j < arr.length; j++){ 
//如果数组中有两个数相等,这里用三位运算符
    if(arr[i] === arr[j]){ 
//在第j个元素开始删除,删除1个元素。splice方法,还可以对多个对象中的某个或某几个对象删除
      arr.splice(j,1);
      j--;
    }
  }
}
console.log(arr)


在这里插入图片描述

map循环配合Array.from去重

const arr = [1, 2, 2, 3, 4, 4, 5];

const newArr = Array.from(new Map(arr.map(item => [item, item])).values());

console.log(newArr); // [1, 2, 3, 4, 5]

这段代码的原理是,先使用map方法将数组元素映射为键值对的数组。然后使用Map构造函数将键值对数组转换为Map对象,其中键和值均为数组的元素。由于Map对象中键是唯一的,这样就自动去除了数组中的重复项。最后,通过Array.from()方法将去重后的Map对象的值转换为新的数组。

set()去重

以下是使用Set数据结构进行数组去重的例子:

let arr = [1, 2, 2, 3, 4, 4, 5];
let newArr = [...new Set(arr)];
console.log(newArr);  // [1, 2, 3, 4, 5]

在这里插入图片描述

这里使用了ES6中的Set数据结构来创建一个去重后的新数组newArr

filter()去重

let arr = [1, 2, 2, 3, 4, 4, 5];
let newArr = arr.filter((value, index, self) => {
  return self.indexOf(value) === index;
});
console.log(newArr);  // [1, 2, 3, 4, 5]

filter()函数遍历数组中的每个元素,并通过比较当前元素在数组中的索引位置来判断是否保留。只有第一次出现的元素会被保留下来,从而实现了去重的效果

在这里插入图片描述


最后

四轮技术面+一轮hr面结束,学习到了不少,面试也是一个学习检测自己的过程,面试前大概复习了 一周的时间,把以前的代码看了一下,字节跳动比较注重算法,面试前刷了下leetcode和剑指offer, 也刷了些在牛客网上的面经。大概就说这些了,写代码去了~

祝大家都能收获大厂offer~

篇幅有限,仅展示部分内容

### JavaScript 中 `Map` 对象的用法 #### 创建 Map 实例 可以使用构造函数创建一个新的 `Map` 对象。 ```javascript const myMap = new Map(); ``` #### 添加键值对到 Map 通过调用 `.set(key, value)` 方法来向 `Map` 中添加新的条目[^1]。 ```javascript myMap.set('key1', 'value1'); myMap.set('key2', 'value2'); ``` #### 获取指定键对应的值 利用 `.get(key)` 来检索存储于给定键中的数据项。 ```javascript console.log(myMap.get('key1')); // 输出 "value1" ``` #### 检查是否存在某个键 `.has(key)` 可用于判断某特定键是否存在于当前映射表内。 ```javascript if (myMap.has('key2')) { console.log("存在 key2"); } ``` #### 删除键及其关联的数据 要移除一对键/值组合,可采用 `.delete(key)` 函数。 ```javascript myMap.delete('key1'); // 返回 true 表明删除成功 ``` #### 清空整个 Map 结构 当需要一次性清除所有的键值对时,应该运用 `.clear()` 方法。 ```javascript myMap.clear(); // 移除所有元素 ``` #### 遍历 Map 内容 遍历操作可以通过多种方式实现,比如使用for...of循环迭代器模式访问每一条记录。 ```javascript // 使用 for..of 循环打印每一组键值对 for (let [key, value] of myMap.entries()) { console.log(`${key} -> ${value}`); } // 或者只获取 keys() 和 values() for (let key of myMap.keys()) { console.log(`Key: ${key}`); } for (let value of myMap.values()) { console.log(`Value: ${value}`); } ``` #### 转换为数组形式 如果希望快速得到由 `[key,value]` 组成的一维或多维数组,则可以直接转换: ```javascript Array.from(myMap); // [[k1,v1],[k2,v2],...] // 或者更简洁的方式 [...myMap]; // 同上效果 ``` 以上就是关于如何在 JavaScript 中定义并操控 `Map` 数据结构的一些基本介绍以及实用的例子。这些特性使得处理复杂类型的集合变得简单而高效[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值