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,一经查实,立即删除!

相关文章

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

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

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

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

计算机二级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…

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

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

理解接雨水算法

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

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

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

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

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

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

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

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

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

如何申请api接口,快速对接数据源

申请API接口并快速对接数据源通常需要以下步骤&#xff1a; 寻找合适的API供应商&#xff1a;首先需要找到提供所需数据的API供应商&#xff0c;可以通过搜索引擎或者专业的API市场找到合适的API接口服务提供商。 注册并获取API密钥&#xff1a;在供应商的网站上注册账户&…

蓝牙物联网多个核心应用场景开发与应用细化分析

蓝牙物联网是指利用蓝牙技术将物理设备与互联网连接起来&#xff0c;实现设备之间的信息共享与互通。蓝牙物联网在各个领域得到了广泛应用&#xff0c;并且在未来有着巨大的发展潜力。本文将围绕蓝牙物联网的五大核心应用场景进行介绍&#xff0c;包括智能家居、智能健康、智能…

文章解读与仿真程序复现思路——电网技术EI\CSCD\北大核心《考虑电氢耦合和碳交易的电氢能源系统置信间隙鲁棒规划》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 这标题涉及到一个复杂的能源系统规划问题&#xff0c;其中考虑了电氢耦合、碳交易和置信间隙鲁棒规划。以下是对标题各个部分的解读&#xff1a; 电氢耦…

矩阵中的最长递增路径

题目链接 矩阵中的最长递增路径 题目描述 注意点 不能 在 对角线 方向上移动或移动到 边界外&#xff08;即不允许环绕&#xff09; 解答思路 因为最长递增路径一定是连续的&#xff0c;所以想到使用深度优先遍历来做。如果只使用深度优先遍历会导致超时&#xff08;同一个…

MT6785安卓核心板_联发科MTK6785/Helio G95/曦力G95核心板定制

MT6785安卓核心板是基于MT6785(Helio G95)处理器&#xff0c;具备八核处理器结构&#xff0c;包括2颗主频为2.05GHz的Cortex A76处理器和6颗主频为2.0GHz的Cortex A55处理器&#xff0c;以及六颗Cortex-A55处理器。而在GPU方面&#xff0c;采用了Arm Mali-G76 MC4&#xff0c;频…

ESP32-Touch(Arduino)

Touch Touch传感器是一种外围设备&#xff0c;具有内部振荡器电路&#xff0c;可在固定时间段内测量相应GPIO引脚上的充电/放电频率。 因此&#xff0c;这些触摸传感器也被称为电容式传感器。例如&#xff0c;如果您触摸这些引脚中的任何一个&#xff0c;手指电荷将改变这个周…

MATHPILE:一个高质量的大规模的数学语料库

简介 MATHPILE&#xff1a;一个高质量、大规模的数学语料库&#xff0c;29 GB&#xff0c;包含约 95 亿个token。涵盖从 K-12 到大学、研究生水平和数学竞赛的内容&#xff0c;包括高质量教科书、讲义、科学论文等。提供详细的数据记录&#xff0c;包括数据集表格和质量注释&a…

渐变登录页

效果演示 实现了一个简单的登录页面的样式和交互效果。 Code <div class"flex"><div class"login color">Login</div><label class"color">Username :</label><input type"text" class"input&…

已安装MySQL5.7的基础上安装MySQL8教程

类似文章很多&#xff0c;但部分问题解决方案并不是很完整&#xff0c;且对细节描述不够清楚&#xff0c;特意总结一篇 在本机已经安装MySQL5.7的情况下新安装MySQL8.x的方案如下&#xff08;请按照步骤详细操作&#xff09;&#xff1a; 1.进入官网下载 https://dev.mysql.c…

【Emgu.CV教程】4.3、无缝融合应用之SeamlessClone()

SeamlessClone()函数才是真正的无缝克隆&#xff0c;它可以将一张小一点的图片&#xff0c;复制到另一张大一点的图片中&#xff0c;并且复制的位置可以用户自己定义&#xff0c;先看一下它的函数介绍&#xff1a; public static void SeamlessClone(IInputArray src, // 输入…