JS中的Set和Map有什么区别?怎么用?

set用于存储唯一值适合去重和存在性检查map用于存储键值对支持任意类型键适合复杂映射和元数据存储。set通过add/has/delete操作自动去重内部使用类似===的相等判断但对nan友好;map通过set/get操作允许对象、函数等作为键且遍历顺序保持插入顺序。两者均提供更高效的查找和更清晰的数据结构选择优于传统对象或数组的部分场景应用。

JS中的Set和Map有什么区别?怎么用?

在JavaScript中,SetMap是两个常用的数据结构,它们都是ES6引入的特性,适合处理需要高效查找、去重或键值映射的场景。虽然它们看起来有点像对象和数组,但各自有明确的使用场景和优势。

Set:用来存储唯一值

Set是一个集合,里面不能有重复的值。它特别适合做数据去重、判断是否存在某个元素等操作。

基本用法:

const s = new Set();s.add(1);s.add(2);s.add(2); // 重复添加无效console.log(s); // 输出: Set { 1, 2 }

常见用途和技巧:

去重数组中的元素:

const arr = [1, 2, 2, 3];const uniqueArr = [...new Set(arr)]; // [1, 2, 3]

判断某个值是否存在:

s.has(1); // true

删除元素:

s.delete(1);

注意:Set内部判断是否相等使用的机制类似于===,但对NaN比较友好(即NaN和NaN视为相同)。

Map:用来存储键值对,支持任意类型的键

Map类似于对象,但它最大的特点是允许任何类型的键(比如对象、函数甚至NaN),不像普通对象只能用字符串或Symbol作为键。

基本用法:

const m = new Map();m.set('name', 'Tom');m.set(1, 'number key');m.set({ id: 1 }, 'object key');console.log(m.get('name')); // Tomconsole.log(m.get(1));      // number key

常见用途和技巧:

使用对象作为键来存储元数据,避免污染对象本身。比普通对象更安全地管理键值关系,尤其是键不确定的时候。遍历顺序保持插入顺序,这点比普通对象更可靠。

注意点:

map.get() 是获取值的方式,不是用.[]

如果你用对象做键,每次传入一个新对象都会被当作不同的键:

const key1 = {};const key2 = {};m.set(key1, 'a');m.set(key2, 'b');console.log(m.size); // 2

Set 和 Map 的区别总结

特性 Set Map

存储内容单一值集合键值对集合是否去重✅自动去重❌不自动去重键类型不适用支持任意类型获取方式遍历或检查存在通过.get(key)获取值常见用途去重、集合运算缓存、元数据存储、复杂映射

基本上就这些了。掌握好SetMap之后,你会发现有些以前需要用对象或数组折腾的逻辑,现在用它们可以更清晰、高效地实现。

以上就是JS中的Set和Map有什么区别?怎么用?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1505510.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 03:45:13
下一篇 2025年12月20日 03:45:24

相关推荐

  • JavaScript中如何存储数据到LocalStorage?

    在javascript中存储数据到localstorage的方法是使用localstorage.setitem(‘key’, ‘value’)。1. 使用setitem存储数据,getitem获取数据,removeitem删除数据,clear清空数据。…

    2025年12月20日
    000
  • 如何用JavaScript判断一个对象是否为空?

    判断javascript对象是否为空可以使用以下两种方法:1. isempty(obj):使用object.keys(obj).length === 0,适用于需要简洁和可读性的场景。2. isemptyfast(obj):使用for…in循环和hasownproperty,适用于需要高…

    2025年12月20日
    000
  • 如何在JavaScript中实现缓存机制?

    在javascript中实现缓存机制可以显著提升应用性能。1) 使用普通对象或map实现简单内存缓存。2) 实现lru缓存以管理缓存空间。3) 考虑缓存失效、并发访问和缓存击穿问题。4) 选择合适的缓存策略和工具,如redis分布式缓存,根据具体需求优化性能。 在JavaScript中实现缓存机制可…

    2025年12月20日
    000
  • js怎么减少内存占用

    减少javascript内存占用的关键方法包括:1. 及时清理不再使用的变量,2. 使用闭包时要小心,3. 避免使用全局变量,4. 使用weakmap和weakset,5. 优化数据结构,6. 避免过度使用字符串拼接,7. 使用内存分析工具,这些策略有助于提升代码性能和应用稳定性。 在JavaScr…

    2025年12月20日
    000
  • JavaScript中如何创建对象字面量?

    在javascript中创建对象字面量的方法是使用大括号 {} 包住键值对。1. 基本用法:const person = { name: “john doe”, age: 30, job: “developer”, sayhello: function…

    2025年12月20日
    000
  • JavaScript中的Array.prototype.some和every有什么区别?

    array.prototype.some方法会在数组中找到至少一个元素满足给定的测试函数时返回true,否则返回false;array.prototype.every方法则要求数组中的所有元素都必须通过测试函数的检查才会返回true,否则返回false。1) some方法适用于验证数组中是否存在满足…

    2025年12月20日
    000
  • 如何用JavaScript阻止事件默认行为?

    在javascript中,阻止事件默认行为可以使用event.preventdefault()或返回false。1)event.preventdefault()阻止默认行为但不阻止事件传播,适用于addeventlistener。2)返回false阻止默认行为和事件传播,仅适用于on事件处理程序。使…

    2025年12月20日
    000
  • JavaScript中如何从LocalStorage读取数据?

    从localstorage读取数据使用localstorage.getitem()方法,需注意数据类型转换、错误处理、数据完整性、性能和安全性。1. 使用localstorage.getitem()读取数据。2. 存储的对象或数组需用json.parse()转换。3. 进行错误处理防止json.pa…

    2025年12月20日
    000
  • 如何用JavaScript判断对象是否为空?

    在JavaScript中,判断对象是否为空是一个常见的需求,尤其在处理数据时,这个问题显得尤为重要。今天我们就来探讨一下如何用JavaScript判断对象是否为空,并深入探讨一些相关的问题和解决方案。 JavaScript中的对象是无处不在的,从简单的键值对到复杂的嵌套结构,判断一个对象是否为空看似…

    2025年12月20日
    000
  • JavaScript中如何获取元素的宽高?

    在javascript中,获取元素的宽高可以通过offsetwidth、clientwidth、offsetheight和clientheight属性实现。1. offsetwidth和offsetheight包含边框和内边距,适合需要考虑边框的场景。2. clientwidth和clienthei…

    2025年12月20日
    000
  • JavaScript中的let和var有什么区别?

    let和var的主要区别在于作用域和变量提升:1. let遵循块级作用域,不会变量提升;2. var遵循函数作用域,会变量提升。使用let可以提高代码的可读性和可维护性,减少错误。 让我们探讨一下JavaScript中的let和var有什么区别,这个问题在开发过程中经常被提及,尤其是在处理变量作用域…

    2025年12月20日
    000
  • JavaScript中的null和undefined有什么区别?

    null和undefined在javascript中有不同的用途和含义。null表示有意设置的空值,undefined表示变量未赋值或属性不存在。使用时应明确赋值,避免依赖默认行为,并使用可选链和空值合并操作符提高代码健壮性。 在JavaScript中,null和undefined常常让初学者感到困…

    2025年12月20日
    000
  • 怎样用JavaScript实现本地存储?

    javascript本地存储有三种主要方法:localstorage、sessionstorage和indexeddb。1. localstorage适合存储小型数据,数据持久化,适合用户设置。2. sessionstorage也用于小型数据,但数据会在会话结束时清除,适合临时数据。3. index…

    2025年12月20日
    000
  • JavaScript中如何遍历对象的所有属性?

    在javascript中,可以使用以下方法遍历对象的所有属性:使用for…in循环和hasownproperty方法,可以遍历对象的所有可枚举属性,但属性顺序不确定。使用object.keys()方法和foreach,可以按顺序遍历对象的所有可枚举属性。使用object.entries(…

    2025年12月20日
    000
  • JavaScript中的事件冒泡和捕获有什么区别?

    事件冒泡是从最具体的元素开始逐级向上传递,而事件捕获是从最不具体的元素开始逐级向下传递。1. 事件冒泡适用于处理复杂用户交互,如表单验证。2. 事件捕获适用于优先处理某些事件,如全局错误处理。3. 实际应用中,需谨慎处理事件传播顺序,灵活使用事件机制。 在JavaScript中,事件冒泡和捕获是处理…

    2025年12月20日
    000
  • JavaScript中的localStorage和sessionStorage有什么区别?

    localstorage用于长期存储数据,sessionstorage仅在会话期间有效。1.localstorage数据持久保留,适合存储用户偏好和学习进度。2.sessionstorage数据仅在当前标签页有效,适合临时数据如购物车内容。两者读写操作同步,需注意性能。 JavaScript中的lo…

    2025年12月20日
    000
  • 怎样用JavaScript实现深比较?

    深比较在javascript中通过递归遍历对象或数组来实现,确保每个嵌套层级都被精确检查。实现步骤包括:1) 检查类型是否相同;2) 处理基本类型;3) 处理数组,通过比较长度和递归比较每个元素;4) 处理对象,通过比较键的数量和递归比较每个键值对。该方法能处理嵌套结构,但需注意性能和循环引用问题。…

    2025年12月20日
    000
  • JavaScript中的for…of和for…in有什么区别?

    for…of用于遍历可迭代对象的值,for…in用于遍历对象的可枚举属性。1.for…of适合数组、字符串等,直接访问元素值。2.for…in适合对象,返回属性名,需谨慎用于数组以避免意外结果。 在JavaScript中,for…of和for……

    2025年12月20日
    000
  • 如何用JavaScript实现本地存储加密?

    使用javascript实现本地存储加密可以通过以下步骤实现:1.使用cryptojs库和aes算法加密数据;2.将加密后的数据存储在localstorage中;3.使用相同的密钥解密数据。该方法能有效保护用户数据的机密性,但需注意密钥管理和性能影响。 用JavaScript实现本地存储加密确实是一…

    2025年12月20日
    000
  • JavaScript中的WeakMap和WeakSet有什么用?

    weakmap和weakset在javascript中用于管理对象生命周期而不阻止垃圾回收。1. weakmap适合存储与对象关联的元数据,不影响对象生命周期。2. weakset用于跟踪已处理对象,防止重复处理。 在JavaScript中,WeakMap和WeakSet是两种特殊的数据结构,它们的…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信