JavaScript中的Map用法完全指南

2025-03-12 17:50

本文主要是介绍JavaScript中的Map用法完全指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《JavaScript中的Map用法完全指南》:本文主要介绍JavaScript中Map用法的相关资料,通过实例讲解了Map的创建、常用方法和迭代方式,还探讨了Map与对象的区别,并通过一个例子展...

引言

JavaScript 中,Map 是一种用于存储键值对的数据结构,具有灵活的键类型和丰富的方法。相较于传统的对象(Object),Map 提供了更高效的键值对操作方式,特别适合处理大量数据和需要频繁操作键值对的场景。本文将详细介绍 Map 的创建、常用方法、迭代方式,并探讨它与对象的区别和实际应用场景。

1. 创建 Map

使用 new Map() 来创建一个空的 Map

const map = new Map();

也可以在创建时初始化 Map,传入一个包含键值对的数组:

const map = new Map([
  ["name", "Alice"],
  ["age", 25]
]);
console.log(map); // 输出 Map(2) { 'name' => 'Alice', 'age' => 25 }

2. Map 和对象的对比

在学习 Map 的基本操作之前,我们先来看一下 Map 与传统对象的区别。

特性Map对象
键的类型任何类型(字符串、对象、函数等)只能是字符串或符号
插入顺序保持插入顺序不保证插入顺序
键值对数量size 属性手动计算(Object.keys().length
原型链污染有,继承 Object.prototype
适用场景频繁操作键值对,大量数据小规模键值对或需要方法时

通过对比可以看出,Map 在键的类型、插入顺序的保持以及键值对操作的效率上,都有显著的优势。

3. Map 的常用方法

3.1 set(key, value)

用于向 Map 添加一个键值对。如果键已经存在,set 会更新其值。

map.set("name", "Bob");
map.set("age", 30);
console.log(map); // 输出 Map(2) { 'name' => 'Bob', 'age' => 30 }

3.2 get(key)

获取指定键的值,如果键不存在,返回 undefined

console.log(map.get("name")); // 输出 'Bob'
coChina编程nsole.log(map.get("gender")); // 输出 undefined

3.3 has(key)

检查 Map 中是否存在指定的键,返回 true 或 false

console.log(map.has("name")); // 输出 true
console.log(map.has("gender")); // 输出 false

3.4 delete(key)

删除指定的键值对,返回 true 如果成功删除,否则返回 false

map.delete("age");
console.log(map); // 输出 Map(1) { 'name' => 'Bob' }

3.5 clear()

清空 Map,删除所有键值对。

map.clear();
console.log(map); // 输出 Map(0) {}

3.6 size

返回 Map 中键值对的数量。

map.set("name", "Alice");
map.set("age", 25);
console.log(map.size); // 输出 2

4. Map 的迭代方法

Map 支持多种迭代方法,可以轻松遍历其中的键值对。

4.1 forEach(callback)

遍历 Map 中的每一个键值对,callback 函数接受三个参数:值、键、Map 本身。

map.forEach((value, key) => {
  console.log(`${key}: ${value}`);
});
// 输出:
// name: Alice
// age: 25

4.2 keys()

返回 Map 中所有键的迭代器(Iterator),可以用&nbChina编程sp;for...of 来遍历。

for (let key of map.keys()) {
  console.log(key);
}
// 输出:
// name
// age

4.3 values()

返回 Map 中所有值的迭代器(Iterator)。

for (let value ofhttp://www.chinasem.cn map.values()) {
  console.log(value);
}
// 输出:
// Alice
// 25

4.4 entries()

返回 Map 中所有键值对的迭代器,每个键值对会以 [key, value] 的形式返回。

for (let entry of map.entries()) {
  console.log(entry);
}
// 输出:
// [ 'name', 'Alice' ]
// [ 'age', 25 ]

4.5 使用 for...of 遍历 Map

可以直接用 for...of 遍历 Map,默认会调用 entries() 方法,因此会返回 [key, value] 的数组。

for (let [key, value] of map) {
  console.log(`${key}: ${value}`);
}
// 输出:
// name: Alice
// age: 25

5. Map 的应用场景

Map 是一种适合存储键值对的结构,尤其适用于以下场景:

  • 需要使用非字符串类型的键:对象的键只能是字符串或符号,而 Map 可以使用任意数据类型作为键,比如对象、函数等。

    const objKey = { id: 1 };
    const map = new Map();
    map.set(objKey, "Object as key");
    console.log(map.get(objKey)); // 输出 'Object as key'
    
  • 需要频繁操作键值对Map 在键值对的查找、插入、删除操作上比对象性能更好,适合在频繁操作键值对的场景下使用。

  • 需要保持插入顺序Map 会按照插入的顺序存储键值对,因此在遍历时顺序是固定的,而对象则不保证插入顺序。

  • 避免原型链污染:对象的键可能会受 Object.prototype 影响,而 Map 没有原型链污染问题,可以安全地存储任意键。

6. 使用 Map 统计字母出现的次数

我们可以通过一个例子来比较使用 Map 和不使用 Map 的差别。假设我们有一个字符串,需要统计其中每个字母出现的次数。Map 非常适合这种键值对存储的场景。

方法 1:不用 Map,使用普通对象

function countLettersWithObject(str) {
  const letterCounts = {}; // 用对象存储字母出现的次数

  for (let letter of str) {
    if (letterCounts[letter]) {
      letterCounts[letter]++;
    } else {
      letterCounts[letter] = 1;
    }
  }

  return letterCounts;
}

const result = countLettersWithObject("hello world");
console.log(result); // 输出: { h: 1, e: 1, l: 3, o: 2, w: 1, r: 1, d: 1 }

方法 2:使用&www.chinasem.cnnbsp;Map

function countLettersWithMap(str) {
  const letterCounts = new Map(); // 用 Map 存储字母出现的次数

  for (let letter of str) {
    if (letterCounts.has(letter)) {
      letterCounts.set(letter, letterCounts.get(letter) + 1);
    } else {
      letterCounts.set(letter, 1);
    }
  }

  return letterCounts;
}

const resultMap = countLettersWithMap("hello world");
console.log(resultMap); // 输出: Map(7) { 'h' => 1, 'e' => 1, 'l' => 3, 'o' => 2, 'w' => 1, 'r' => 1, 'd' => 1 }

7. WeakMap 简介

WeakMap 是 Map 的一种特殊类型,它的键必须是对象,且是弱引用(即不会阻止对象被垃圾回收)。如果某个对象在其他地方不再被引用,那么即使它是 WeakMap 的键,也会被垃圾回收,这样可以防止内存泄漏。

WeakMap 的特点

  • 只接受对象作为键,不支持基本类型。
  • 键是弱引用,不会阻止垃圾回收。
  • 没有 size 属性、clear 方法和遍历方法(forEachkeysvaluesentries),因此不能遍历 WeakMap

使用场景

WeakMap 通常用于私有属性或私有数据的存储,不希望这些数据影响垃圾回收。它适用于对象间的临时映射关系,且在数据无需遍历的情况下使用。

const weakMap = new WeakMap();
let obj = { id: 1 };

weakMap.set(obj, "some value");
console.log(weakMap.get(obj)); // 输出 'some value'

obj = null; // 删除对象的其他引用
// 在此之后,obj 被垃圾回收,WeakMap 中的键值对也会被清除

总结

Map 是一种强大的键值对数据结构,具有灵活的键类型支持、保持插入顺序、丰富的内置方法等优势,适合存储和操作大量键值对。而 WeakMap 则是一种针对对象键的弱引用 Map,在特定场景China编程中帮助管理内存。希望这些内容能帮助你全面理解和应用 Map

到此这篇关于javascript中Map用法的文章就介绍到这了,更多相关js中Map用法内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于JavaScript中的Map用法完全指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153712

相关文章

JAVA SE包装类和泛型详细介绍及说明方法

《JAVASE包装类和泛型详细介绍及说明方法》:本文主要介绍JAVASE包装类和泛型的相关资料,包括基本数据类型与包装类的对应关系,以及装箱和拆箱的概念,并重点讲解了自动装箱和自动拆箱的机制,文... 目录1. 包装类1.1 基本数据类型和对应的包装类1.2 装箱和拆箱1.3 自动装箱和自动拆箱2. 泛型2

SpringBoot操作MaxComputer方式(保姆级教程)

《SpringBoot操作MaxComputer方式(保姆级教程)》:本文主要介绍SpringBoot操作MaxComputer方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录引言uqNqjoe一、引入依赖二、配置文件 application.properties(信息用自己

Javascript访问Promise对象返回值的操作方法

《Javascript访问Promise对象返回值的操作方法》这篇文章介绍了如何在JavaScript中使用Promise对象来处理异步操作,通过使用fetch()方法和Promise对象,我们可以从... 目录在Javascript中,什么是Promise1- then() 链式操作2- 在之后的代码中使

JAVA虚拟机中 -D, -X, -XX ,-server参数使用

《JAVA虚拟机中-D,-X,-XX,-server参数使用》本文主要介绍了JAVA虚拟机中-D,-X,-XX,-server参数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录一、-D参数二、-X参数三、-XX参数总结:在Java开发过程中,对Java虚拟机(JVM)的启动参数进

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

Java中使用注解校验手机号格式的详细指南

《Java中使用注解校验手机号格式的详细指南》在现代的Web应用开发中,数据校验是一个非常重要的环节,本文将详细介绍如何在Java中使用注解对手机号格式进行校验,感兴趣的小伙伴可以了解下... 目录1. 引言2. 数据校验的重要性3. Java中的数据校验框架4. 使用注解校验手机号格式4.1 @NotBl

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

SpringBoot基于沙箱环境实现支付宝支付教程

《SpringBoot基于沙箱环境实现支付宝支付教程》本文介绍了如何使用支付宝沙箱环境进行开发测试,包括沙箱环境的介绍、准备步骤、在SpringBoot项目中结合支付宝沙箱进行支付接口的实现与测试... 目录一、支付宝沙箱环境介绍二、沙箱环境准备2.1 注册入驻支付宝开放平台2.2 配置沙箱环境2.3 沙箱

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4