JavaScript中解锁Map和Set的力量

🧑‍🎓 个人主页:《爱蹦跶的大A阿》

🔥当前正在更新专栏:《VUE》 、《JavaScript保姆级教程》、《krpano》

​ 

✨ 前言

        ES6带来了Map和Set两个新的数据结构 - 它们分别用于存放键值对和唯一值。Map和Set提供了更优雅和高效的存取与操作数据的方式。本文将全面解析Map和Set的用法及应用场景,助你提升JavaScript数据处理能力。

第一节:Map概述

Map是ES6新增的一种键值对集合,类似于Object。区别在于:

  • Map的键可以是任意类型,Object的键只能是字符串或符号。
  • Map的大小可以直接获取,Object则需手动计算。
  • Map有更多方便的方法,如size、clear等。

Map提供了对键值对的存储与操作,键的顺序也得到保留。

第二节:创建和初始化Map

可以通过构造函数创建Map:

let map = new Map();

Map可以接受数组做为参数,进行初始化:

new Map([['key1', 'val1'],['key2', 'val2'], 
]);

 也可以链式调用set方法初始化:

new Map().set('a', 1).set('b', 2);

第三节:Map的基本操作

  • set(key, val) 添加元素
  • get(key) 通过键查找值
  • has(key) 判断键是否存在
  • delete(key) 通过键删除元素
  • clear() 清空所有元素

Map使键值对的操作更简洁直观。后面将介绍Map的遍历等高级用法。

 

第四节:遍历Map

常用的Map遍历方式:

  • keys() - 遍历键名
  • values() - 遍历键值
  • entries() - 遍历键值对
  • forEach() - 遍历回调函数

示例:

let map = new Map([[1, 'a'], [2, 'b']]);for (let key of map.keys()) {// ...
}for (let value of map.values()) {// ...
}for (let [key, value] of map.entries()) {// ...
}map.forEach(function(value, key) {// ...
})

第五节:WeakMap

WeakMap与Map的区别:

  • WeakMap只接受对象作为键名
  • WeakMap的键名所指向的对象不计入GC ROOT
  • WeakMap不可遍历

WeakMap使用场景:

  • 作为对象的元数据储存
  • 缓存数据

第六节:Set的概述

Set是一种包含唯一值的集合,可以高效地对值进行操作。

Set具有以下特点:

  • 成员值唯一,没有重复值
  • 值的顺序不重要,也不能索引
  • 支持高效的查找、删除操作

第七节:创建和初始化Set

可以通过构造函数创建Set:

let set = new Set();

也可以传入数组或者iterable对象进行初始化: 

new Set([1, 2, 3]);new Set('hello');

第八节:Set的基本操作

  • add(value) 添加元素
  • delete(value) 删除元素
  • has(value) 检查是否存在
  • clear() 清空所有元素

Set使得处理唯一值更简单。

第九节:遍历Set

  • keys() 返回键名的迭代器
  • values() 返回键值的迭代器
  • entries() 返回键值对的迭代器
  • forEach() 遍历回调函数

示例:

 

let set = new Set([1, 2]);for (let key of set.keys()) {// ...
}for (let value of set.values()) {// ... 
}set.forEach(function(value) {// ...
})

第十节:WeakSet

WeakSet与Set的区别:

  • 只接受对象作为成员
  • 对象不计入垃圾回收机制中
  • 不可遍历

使用场景:存储DOM节点,不会泄漏内存。

Map和Set大大提高了数据处理能力,了解其用法可以使代码更简洁优雅。

 

第十一节:Map的应用

  • 作为对象的替代,当键需要非字符串时
const map = new Map();
map.set(obj, value);
  • 存储键值对数据集合
  • 映射关系表
  • 频率表记录出现次数
  • 缓存数据

第十二节:Set的应用

  • 去重数组
const set = new Set(arr);
  • 交集、并集、差集运算
  • 删除数组重复值
[...new Set(arr)]
  • 测试值是否存在于某集合
  • 存储不重复数据,如Tags

Map和Set拓展了数据处理能力,在数据操作方面有很多实际应用,值得我们深入学习。

✨ 结语

  • Map用于存储键值对,键可以是任意类型。
  • Set用于存储唯一值,没有重复值。
  • Map和Set都可以高效地增删查找。
  • Map支持按插入顺序遍历,Set不保证顺序。
  • WeakMap和WeakSet用于存储对对象的弱引用。
  • Map和Set在处理数据时有许多应用场景。

要点:

  • 理解Map与Object、Set与Array的区别
  • 掌握各自的初始化、增删查API
  • 合理运用Map或Set,不要滥用
  • WeakMap和WeakSet用于特定场景
  • 多在实际中练习 Map和Set的应用

        Map和Set提供了更优雅高效的 JavaScript 数据处理能力,值得我们深入学习,并合理运用到实际项目中。

        这就是本文的全部内容了。如果对Map和Set的使用还有任何疑问,欢迎在评论区留言讨论!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/609961.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端国际化之痛点(三):上线后修改翻译内容

前言 VoerkaI18n是一款非常优秀的前端国际化解决方案,其开发的出发点是为了解决现存多语言的一些痛点,接下来几篇文章将分别进行分析 前端国际化之痛点(一):让人头疼的词条Key前端国际化之痛点(二):多包多库场景下联动多语言前端国际化之痛…

深入浅出Go语言:匿名函数的原理和实践案例

深入浅出Go语言:匿名函数的原理和实践案例 引言匿名函数的基础实际应用案例一实际应用案例二性能考虑最佳实践与常见错误结语 引言 在Go语言的世界里,有一个功能强大且灵活的编程元素值得每位开发者深入了解——匿名函数。作为Go语言核心特性之一&#…

AI论文润色平台一览,让你的论文更加流畅易懂!

之前其实比较犹豫,是否应该整理一篇关于可辅助论文写作的在线平台的文章。因为论文这个事情,更重要的是要有个人的思考,要亲自动手写,这涉及到诚信的问题。然而,通过AI直接生成的论文可能很难通过查重和AI检测&#xf…

计算机网路——延迟

1. 延迟 在数据传输过程中,从发射器到接收器,数据会遇到的不同类型的延迟。 1.1 延迟的种类 1.1.1 发射持续时间 这个时间段与数据的大小成正比,并且与网络的带宽成反比。也就是说,如果数据段很长或者网络带宽较小,那…

计算机二级WPS Office考试须知、如何备考、备考建议

本文从计算机二级考试须知、如何备考、备考建议以及考试的注意事项等方面进行讲述,认认真真看,对你受益匪浅。 一、计算机二级考试须知 2021年3月27日至29日将举办第60次全国计算机等级考试(NCRE),从今年起&#xff0…

40-特殊运算符delete,new,.getDate,.setDate,运算符优先级

1.delete删除. 数组 // 可以删除数组元素,可以删除对象键值对// 删除数组的值,数组长度保持不变// 删掉的值变成emptyvar arr [1,2,3,4,5];delete arr[0];console.log(arr); 对象 var obj {"a":"aa","b":"bb&quo…

前端基础面试题

一、HTML 1.行内元素有哪些?块级元素有哪些? 空(void)元素有哪些? 行内元素:span、img、input... 块级元素:div、footer、header、section、p、h1...h6... 空元素:br、hr... 2.元素之间…

什么是云安全?如何保护云资源

云计算允许组织通过互联网按需向其客户、合作伙伴或员工提供关键业务应用程序、服务和资源。换句话说,不再需要物理维护资源。每当您通过 Internet 从计算机访问文件或服务时,您都是在访问云。 迁移到云可以帮助企业增强安全性、简化运营并降低成本。企…

理解接雨水算法

一、IDEA注释显示图片 在做题时&#xff0c;需要对照这图片&#xff0c;才能更好的梳理思路。 首先&#xff0c;注释里添加<img/>标签 之后&#xff0c;将鼠标光标放置在需要以阅读模式预览注释的地方&#xff0c;然后按快捷键CtrlAltQ即可 二、接雨水算法 先看接雨水…

C++经典程序

C有许多经典的程序示例&#xff0c;以下是其中一些简单但常见的例子&#xff0c;以帮助你更好地了解C语言的基本概念。 1. **Hello World程序:** cpp #include <iostream> int main() { std::cout << "Hello, World!" << std…

【SPDK】【NoF】使用SPDK部署NVMe over TCP

SPDK NVMe over Fabrics Target是一个用户空间应用程序&#xff0c;通过以太网&#xff0c;Infiniband或光纤通道等结构呈现块设备,SPDK目前支持RDMA和TCP传输。 本文将在已经编译好SPDK的基础上演示如何使用SPDK搭建NVMe over TCP&#xff0c;前提是您已经将一块NVMe硬盘挂载…

Python使用函数统计指定数字的个数

本题要求实现一个统计整数中指定数字的个数的简单函数。 CountDigit(number,digit )其中number是整数&#xff0c;digit为[1, 9]区间内的整数。函数CountDigit应返回number中digit出现的次数。 函数接口定义&#xff1a; 在这里描述函数接口。例如&#xff1a; CountDigit(n…

Android Room数据库升级Migration解决方案

一、介绍 Android Room 是 Android 官方提供的一个轻量级数据库框架&#xff0c;用于在 Android 应用程序中管理数据持久性。它简化了数据库访问&#xff0c;提供了更安全、更快速的数据存储方式&#xff0c;并使得数据操作更加便捷。 二、Room的特点(八股文可以参考) 以下是…

【Spring实战】27 统一异常处理最佳实践

文章目录 1. 自定义异常2. 统一异常处理3. 配置4. 应用5. 启动类6. 启动服务7. 验证8. 优点总结 在 Spring 项目中&#xff0c;有效的异常处理是确保应用程序稳定性和用户体验的关键因素之一。通过实现统一异常处理&#xff0c;我们能够更好的管理和响应应用程序中的各种异常情…

Hadoop之mapreduce参数大全-2

25.指定在Reduce任务在shuffle阶段的fetch操作中重试的超时时间 mapreduce.reduce.shuffle.fetch.retry.timeout-ms是Apache Hadoop MapReduce任务配置中的一个属性&#xff0c;用于指定在Reduce任务在shuffle阶段的fetch操作中重试的超时时间&#xff08;以毫秒为单位&#x…

Phi-2小语言模型QLoRA微调教程

前言 就在不久前&#xff0c;微软正式发布了一个 27 亿参数的语言模型——Phi-2。这是一种文本到文本的人工智能程序&#xff0c;具有出色的推理和语言理解能力。同时&#xff0c;微软研究院也在官方 X 平台上声称&#xff1a;“Phi-2 的性能优于其他现有的小型语言模型&#…

安卓(雷电)模拟器清除屏幕密码

1、设置磁盘可写 启动模拟器&#xff0c;然后在模拟器的设置界面&#xff0c;设置磁盘共享为可写入&#xff0c;重启模拟器&#xff0c;如下图&#xff1a; 2、找到模拟器目录 返回桌面&#xff0c;右键模拟器图标&#xff0c;打开文件所在目录&#xff0c;如下图&#xff1a…

Arduino驱动ISD1820音频录放模块(声音传感器)

目录 1、传感器特性 2、硬件原理图 3、控制器和传感器连线图 4、驱动程序 ISD1820录放音模块,集成录放音功能为一体。板载按键和麦克风,可直接通过

javaWebssh校园物业管理系统myeclipse开发mysql数据库MVC模式java编程计算机网页设计

一、源码特点 java ssh校园物业管理系统是一套完善的web设计系统&#xff08;系统采用ssh框架进行设计开发&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用 B/S模式开发。开发环境为TOMCAT7.…

洛谷 P8833 [传智杯 #3 决赛] 课程 讲解

前言&#xff1a; 大家好&#xff01; 我们又见面啦~~~ 对于我20多天没上号&#xff0c;深表歉意&#xff01;&#xff01; 希望大家给我的account点一个赞&#xff0c;加一个粉丝&#xff0c;谢谢&#xff01; 也对CSDN的所有博主们送上衷心的祝福&#xff01; 如有错误…