Map对象在JavaScript循环中的使用

在JavaScript中,Map对象是一种新的键值对集合数据结构,与传统的Object有着本质的差异。一个Map的键可以是任意值,包括函数、对象或任何原始值。Map对象与传统的Object相比,有以下几个显著的优点:

  • 键的范围不限于字符串和Symbol。
  • Map对象的键值对是有序的,即键值对的插入顺序是如何,迭代顺序就是如何。
  • Map 的大小可以通过 size 属性轻松获取,而不是像Object那样必须手动计算。
  • Map 是可迭代的,可以直接使用 for...of 循环进行迭代。
  • Map 进行迭代效率比Object的迭代(例如,使用 Object.keys 或者 Object.entries)要来得高。

在JavaScript中进行循环操作时,使用Map对象,你可以采用多种方式进行迭代,它们分别有着不同的用途和语法结构。

for...of 循环

for...of 循环直接迭代Map中的键值对,它返回每个项的[key, value]数组。

复制代码
let myMap = new Map();
myMap.set('key1', 'value1');
myMap.set('key2', 'value2');

for (let [key, value] of myMap) {
  console.log(key, value);
}
​

forEach() 方法

Map对象的 forEach() 方法类似于数组的 forEach() 方法,它按照插入顺序迭代每个键值对,并执行提供的回调函数。

复制代码
myMap.forEach((value, key) => {
  console.log(key, value);
});
​

迭代器方法

Map对象提供了三个迭代器方法:keys()values()entries()。这些方法返回新的迭代器对象,你可以用 for...of 循环或者其他迭代器协议的方法来遍历。

  • keys() 迭代Map中的键。

  • values() 迭代Map中的值。

  • entries() 迭代Map中的项即键值对。

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

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

    for (let [key, value] of myMap.entries()) {
    console.log(key, value);
    }

使用展开运算符

你还可以通过展开运算符 ... 去将Map对象的 keysvalues、或 entries 迭代器转换成数组。

复制代码
console.log([...myMap.keys()]);   // 输出所有的键
console.log([...myMap.values()]); // 输出所有的值
console.log([...myMap.entries()]); // 输出所有的键值对
​

由于Map对象跟传统的对象类似,但提供了更多的迭代功能,它被广泛用来代替Object存储键值对。适当的使用Map和配套的迭代方法,可以让代码更加清晰,提高数据操作的灵活性和效率。在数据量大或者对迭代顺序有特定需求时,Map会是一个很好的选择。

相关推荐
草履虫建模10 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
华玥作者12 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
naruto_lnq12 小时前
分布式系统安全通信
开发语言·c++·算法
Mr Xu_12 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠12 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
学嵌入式的小杨同学12 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
sleeppingfrog12 小时前
zebra通过zpl语言实现中文打印(二)
javascript
lang2015092812 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
Re.不晚13 小时前
Java入门17——异常
java·开发语言
精彩极了吧13 小时前
C语言基本语法-自定义类型:结构体&联合体&枚举
c语言·开发语言·枚举·结构体·内存对齐·位段·联合