JavaScript中的new map()和new set()使用详细(new map()和new set()的区别)

Map 对象是一种键值对的集合,其中的键是唯一的,值可以重复。
new Set(): 在JavaScript中, new Set() 是用来创建一个新的 Set 对象的语法。Set 对象是一种集合,其中的值是唯一的,没有重复的值。 new Set() 可以用来创建一个空的 Set 对象,在创建时传入一个数组或类数组对象,Set 会自动去除重复的值。
new Map()
一、new Map() 基本特性
new Map() 是用来创建一个新的 Map 对象的构造函数。Map 对象保存键值对,并记住键的原始插入顺序。这意味着你可以迭代 Map 对象,按键的插入顺序获取键值对。

Map 对象与普通的对象(使用字符串作为键)不同,因为 Map 可以使用任何类型作为键(包括函数、对象或任何原始值),而不仅仅是字符串或符号。

二、相关方法
1. set(key, value) : 向 Map 对象中添加一个键值对。
2. get(key) : 获取指定键对应的值。
3. has(key) : 判断 Map 对象中是否存在指定的键。
4. delete(key) : 删除指定键及其对应的值。
5. size : 返回 Map 对象中键值对的数量。
6. clear() : 清空 Map 对象中的所有键值对。
7. keys() : 返回一个包含 Map 对象中所有键的迭代器。
8. values() : 返回一个包含 Map 对象中所有值的迭代器。
9. entries() : 返回一个包含 Map 对象中所有键值对的迭代器。
三、基本使用

// 创建一个新的Map对象  
let myMap = new Map();  
  
// 1、添加键值对  
myMap.set('name', 'Alice');  
myMap.set('age', 25);  
  
// 2、获取值  
console.log(myMap.get('name')); // 输出: "Alice"  
  
// 3、检查键是否存在  
console.log(myMap.has('age')); // 输出: true  
  
// 4、删除键值对  
myMap.delete('name');  
console.log(myMap.has('name')); // 输出: false  
 
// 5、获取Map的大小  
console.log(myMap.size); // 输出: 1  
  
// 6、清空Map  
myMap.clear();  
console.log(myMap.size); // 输出: 0  
  
// 7、遍历键  
for (let key of myMap.keys()) {  
  console.log(key); // 输出: "age"  
}  
  
// 8、遍历值  
for (let value of myMap.values()) {  
  console.log(value); // 输出: 25  
}  
  
// 9、遍历键值对  
for (let [key, value] of myMap.entries()) {  
  console.log(`Key: ${key}, Value: ${value}`); // 输出: Key: age, Value: 25  
}  

new Set()
一、new Set() 基本特性
唯一性:在 Set 中,每个值只出现一次,可以实现简单的数组去重,即使是两个完全相同的对象,它们在 Set 中也只会被存储一次。
无序性:Set 中的元素没有特定的顺序。
二、相关方法
add(value): 向 Set 对象中添加一个值。如果值已存在,则不会进行任何操作。
delete(value): 从 Set 对象中删除一个值。如果值存在,则删除并返回 true;否则,返回 false。
has(value): 返回一个布尔值,表示 Set 对象中是否包含指定的值。
clear(): 清空 Set 对象,移除所有元素。
三、基本使用

let setData = new Set();  
  
// 添加元素  
setData .add(1);  
setData .add(2);  
setData .add(3); 
console.log(setData); // setData { 1, 2 ,3 }  
 
// 删除元素  
setData.delete(2);  
console.log(setData); // Set { 1, 3 }  
 
  
// 检查元素是否存在  
console.log(setData.has(1)); // true  
console.log(setData.has(4)); // false  
  
// 遍历元素  
setData.forEach(value => console.log(value));  
// 输出:  
// 1  
// 3
 
// 清空集合  
setData.clear();  
console.log(setData.size);    // 输出: 0,因为集合已被清空
 
 
//在创建 Set 时直接传入一个可迭代对象(如数组),来初始化 Set:
let set = new Set([1, 2, 2, 3, 4, 4]);  
//简单数组去重
console.log(set); // Set { 1, 2, 3, 4 }

.什么是set()
Set是es6新增的数据结构,似于数组,但它的一大特性就是所有元素都是唯一的,没有重复的值,我们一般称为集合。Set本身是一个构造函数,用来生成 Set 数据结构

2.使用情形
new Set()生成出来的数据是Set数据结构,需要自行转换成对应结构

2.1 用于数组去重

2.2 用于字符串去重

3.增删改查
3.1添加元素add

对于存在的元素,不会进行再次添加处理

 3.2是否存在元素has

返回boolen类型,判断是否是set内的成员元素

3.3删除元素delete

删除的是值,而不是下标

3.4清楚所有元素clear

执行后没有返回值

4.遍历方法

4.1 遍历 keys()

返回键名的遍历器,相等于返回键值遍历器values()


4.2 遍历 values()

返回键值的遍历器

4.3 遍历 entries()

返回键值对的遍历器

4.4 遍历 forEach()

使用回调函数遍历每个成员

### JavaScript 中 `Map` `Set` 的用法及区别 #### 使用方法 在 JavaScript 中,`Map` 对象保存键值对,并记住元素的原始插入顺序。任何值(对象或基本类型)都可以作为键或值。 ```javascript // 创建一个新的 Map 实例 const map = new Map(); map.set('key1', 'value1'); map.set('key2', 'value2'); console.log(map.get('key1')); // 输出 "value1" console.log(map.size); // 输出 2 ``` 相比之下,`Set` 是一个集合数据结构,用于存储唯一的值序列,无论是原始值还是对象引用。 ```javascript // 创建一个新的 Set 实例 const set = new Set(); set.add(1); set.add(2); console.log(set.has(1)); // 返回 true console.log(set.size); // 输出 2 ``` #### 主要差异 - **唯一性**:`Set` 只能包含独一无二的成员;而 `Map` 则允许重复的键[^1]。 - **访问方式**:对于 `Map` 来说,可以通过指定的键来获取对应的值;而对于 `Set` 而言,则不存在这样的概念——它只关心是否存在某个特定项。 - **遍历行为**:两者都支持迭代器协议,可以方便地通过 for...of 循环或者其他形式来进行遍历操作。但是由于它们内部储存的数据性质不同,在实际应用中的表现也会有所差别: ```javascript const myMap = new Map([['a', 1], ['b', 2]]); for (let [key, value] of myMap) { console.log(`${key} = ${value}`); } const mySet = new Set(['apple', 'banana']); for (let item of mySet) { console.log(item); } ``` - **性能考量**:当涉及到大量查找、删除等操作时,通常认为 `Set` 在处理去重方面具有更好的效率优势;而在关联映射场景下,`Map` 显得更加合适一些。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值