Map 对象的基础知识介绍

引言

Map 对象是一种键值对存储的数据结构,它可以用于存储任意类型的值,并提供了快速的查找和迭代功能。Map 中的键可以是任意类型的值,包括字符串、数字、符号、对象等,而值也可以是任意类型的值,包括数字、字符串、布尔值、对象等。

Map 对象的出现极大地提高了前端处理数据的效率,今天我们来总结一下 Map 的一些基本方法。

get(key)

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

javascript 复制代码
let map = new Map();
map.set('a', 1);
console.log(map.get('a')); // 1
console.log(map.get('b')); // undefined

set(key, value)

设置指定 key 对应的值,如果 key 已存在则会覆盖原有的值。

JavaScript 复制代码
let map = new Map();
map.set('a', 1);
const obj1 = {
    name: "obj"
};
const obj2 = {
    age: 99
};
map.set(obj1, obj2);
console.log(map.get('a')); // 1
console.log(map.get(obj1)); // {age: 99}
map.set('a', 2);
console.log(map.get('a')); // 2

delete(key)

删除指定键值对,删除成功则返回 true,如果键不存在则返回 false。

javascript 复制代码
let map = new Map();
map.set('a', 1);
console.log(map.delete('a')); // true
console.log(map.get('a')); // undefined
map.delete('a'); // false

has(key)

判断指定 key 是否存在于 Map 中,如果存在则返回 true,否则返回 false。

javascript 复制代码
let map = new Map();
map.set('a', 1);
console.log(map.has('a')); // true
console.log(map.has('b')); // false

clear()

清空 Map 中所有的键值对。

javascript 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.clear();
console.log(map.size); // 0

entries()

Map.entries() 返回 Map 中所有键值对的迭代器,其中包含了 Map 中所有的键值对。

可以使用 for...of 循环或者 reduce() 方法遍历 Map.entries() 返回的迭代器。

javascript 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);

const entries = map.entries();
console.log(entries); // MapIterator {'a' => 1, 'b' => 2, 'c' => 3}

for (const entry of entries) {
  console.log(entry[0] + ': ' + entry[1]);
}

// 输出:
// a: 1
// b: 2
// c: 3

keys()

Map.keys() 返回 Map 中所有键的迭代器。

javascript 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);

const keys = map.keys();
console.log(keys); // MapIterator {'a', 'b', 'c'}

for (const key of keys) {
  console.log(key);
}

// 输出:
// a
// b
// c

values()

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

js 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);

const values = map.values();
console.log(values); // MapIterator {1, 2, 3}

for (const value of values) {
  console.log(value);
}

// 输出:
// 1
// 2
// 3

forEach(callbackFn, thisArg)

对 Map 中的键值对执行回调函数,并对每个键值对执行一次。

回调函数可以接受三个参数:

  • 当前键值对的值
  • 当前键值对的键
  • Map 本身
javascript 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);

map.forEach((value, key) => {
  console.log(key + ': ' + value);
});

// 输出:
// a: 1
// b: 2
// c: 3

size

获取 Map 中键值对的数量。

javascript 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);
console.log(map.size); // 3

Map 对象的遍历方法

Map 的遍历除了上面介绍的 forEach 方法,还有 for...of 方法。

javascript 复制代码
let map = new Map();
map.set('a', 1);
map.set('b', 2);
map.set('c', 3);

for (const [key,value] of map) {
    console.log(`${key}: ${value}`);
}

// 输出:
// a: 1
// b: 2
// c: 3

结束语

关于 Map 对象的一些基础知识就总结这么多,希望能够对大家有所帮助。

~

~ 全文完,感谢阅读!

~

相关推荐
古茗前端团队1 小时前
急招!前端|测试|后端|产品(名额多,速来)
前端·后端·架构
Lsx_2 小时前
不只是 Prompt:用 Superpowers Skill 给 AI 编程装上工程化工作流
前端·ai编程·claude
用户938515635072 小时前
从 Prompt 到 Harness:AI 工程化的三年跃迁与实战解码
javascript·人工智能
小碗细面2 小时前
前端 Prompt 工程实战:如何搭建场景化 Prompt 库
前端·ai编程
阿瑞IT2 小时前
2026年 AI Agent 生产化落地全景:四大高频故障根因分析与工程解法
前端
木木剑光2 小时前
我开源了一个 React 组件库,沉淀了多个高频组件和实用 Hooks
前端·javascript·react.js
kyriewen2 小时前
DeepSeek API 高峰时段涨价 2 倍,便宜大碗的时代要结束了?
前端·ai编程·deepseek
Moment3 小时前
牛逼,NextJs 从 16.3 开始全面拥抱 Agent Native 🥰🥰🥰
前端·后端·面试
沸点小助手3 小时前
6月沸点活动获奖名单公示|本周互动话题上新🎊
前端·后端
Csvn3 小时前
React 19 `use()` 来了:以后数据加载可以不用 useEffect?
前端·react.js