javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > js map使用

JavaScript数据结构Map的使用实例详解

作者:Hi_MrXiao

JavaScript中Map是ES6引入的数据结构,键可为任意类型,保留插入顺序,支持迭代和size属性,相比对象更灵活高效,适合复杂键和有序场景,但需注意对象键引用比较及NaN的特殊处理,本文给大家介绍JavaScript数据结构Map的使用,感兴趣的朋友一起看看吧

在 JavaScript 中,Map 是 ES6 引入的一种新的数据结构,它类似于对象,也是键值对的集合,但 Map 的键可以是任意类型的值(对象、函数、基本类型等),而传统对象的键只能是字符串或 Symbol,并且Map保留了插入顺序。

一、Map 的特性

二、创建 Map

1、‌创建一个空 Map

const emptySet = new Map();

2、创建一个带有初始键值对的 Map,通过二维数组初始化

const map2 = new Map([
  ['name', '张三'],
  ['age', 25],
  [1, '数字键'],
  [{}, '对象键']
]);

三、Map 的常用属性和方法

四、遍历 Map

1、 for…of 循环

const map = new Map([
  ['a', 1],
  ['b', 2],
  ['c', 3]
]);

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

2、forEach 方法

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

3、获取迭代器

五、Map 与 Object 的比较

特性MapObject
键的类型任意值String 或 Symbol
键的顺序插入顺序不一定
大小size属性手动计算
性能(频繁增删)更优一般
序列化不能直接JSON序列化可以直接序列化
默认键有原型链上的键

六、与对象/数组的转换‌

1、对象转为Map‌

const obj = { a: 1, b: 2 };
const map = new Map(Object.entries(obj));

2、Map转为对象‌

const map = new Map([["a", 1], ["b", 2]]);
const obj = Object.fromEntries(map);

3、Map转为数组‌

console.log([...map]); // 转二维数组
console.log([...map.keys()]); // 所有键的数组

七、使用场景

八、使用示例

1、统计字符出现次数

function countChars(str) {
  const result = new Map();
  for (const char of str) {
    result.set(char, (result.get(char) || 0) + 1);
  }
  return result;
}

const charCount = countChars('hello world');
console.log(charCount.get('o')); // 2

2、使用复杂对象作为键

const user1 = {id: 1, name: 'admin'};
const user2 = {id: 2, name: 'test'};

const userMapData = new Map();
userMapData.set(user1, {roleCode: 'admin', createTime: '2025-04-09'});
userMapData.set(user2, {roleCode: 'user', createTime: '2025-04-09'});

console.log(userMapData.get(user1).roleCode); // 'admin'

3、对象关联元数据
dom对象本身作为键存储额外数据,避免污染对象属性

const domMetadata = new Map();
const button = document.querySelector("#myButton");

// 绑定点击次数元数据
domMetadata.set(button, { clickCount: 0 });

button.addEventListener("click", () => {
  const metadata = domMetadata.get(button);
  metadata.clickCount++;
  console.log(`点击次数:${metadata.clickCount}`);
});

九、注意事项

1、对象作为键时: Map 的键是基于引用比较的,两个看起来相同的对象作为键是不同的

const map = new Map();
map.set({}, 'value1');
map.set({}, 'value2');
console.log(map.size, map.get({}));  // 2 undefined(不同引用)

let obj = {};
map.set(obj, 'value3');
console.log(map.obj); // value3

2、 NaN 作为键时: 虽然 NaN !== NaN,但在 Map 中被视作同一键

map.set(NaN, 'not a number');
console.log(map.get(NaN)); // 'not a number'

Map 是一种强大且灵活的数据结构,通过灵活使用 Map,可以更高效地处理复杂键类型和有序键值对的场景,提升代码可读性和性能。

到此这篇关于JavaScript数据结构Map的使用实例详解的文章就介绍到这了,更多相关js map使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文