new Map() 和 new Set()的用法(javascript)

1 作用

Map() 用来存储键值对,是键值对的集合;即用来管理键值对(key:value)

Set() 用来存储键,是键的集合;即用来管理一组键(key)

2 Map()基础用法

如下,可以在控制台测试map集合的基础方法

// 新建Map集合
var m1=new Map()
// 添加键值对
m1.set("name","xiaobaigis")
// 添加键值对
m1.set(5,"number")
// 获取指定键的值
m1.get(5)
m1.get("name")
// 判断是否有指定键
m1.has(5)
// 删除指定键
m1.delete(5)
// 再判断是否存在某指定键
m1.has(5)
// 清空map集合
m1.clear()
// 获取集合大小
m1.size()

通过观察可以发现: 键名可以是数字,字符串,对象等类型

3 Set()基础用法

根据如下步骤,在控制太操作set集合,直观感受set集合的特点

// 创建set空集合
var s1=new Set()
// 添加数字
s1.add(2)
// 添加数字
s1.add(2)
// 添加字符串
s1.add('name')
// 添加对象
s1.add({})
// 判断是否存在该键
s1.has(2)
// 判断是否存在该键
s1.has(3)
// 删除键2
s1.delete(2)
// 判断是否存在该键
s1.has(2)
// 集合大小
s1.size

通过观察可以发现:

1 set集合可以添加数字,字符串,对象等类型的键,

2 键不重复

初始化set集合;

var s2 =new Set([2,3,4,5,63,2,3,2,3])  // {2, 3, 4, 5, 63}
var s3 =new Set(["name","sfd","name"]) // {'name', 'sfd'}

所以Set集合可以用来数组去重;

4 总结

在平时,map和set用的比较少;是因为map和对象很像,set和数组很像;那什么场景使用这两种数据结构呢

如果要求键名类型不限于字符串,那么可以选择Map();

如果要管理一组唯一的键组合,则可以选择Set();

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
JavaScript中,Map是一种数据结构,它可以将键值对存储在一个对象中,其中键和值可以是任何类型的数据。Map的使用方法非常简单,可以使用new操作符和Map构造函数来创建一个新的Map对象。例如: ``` let map = new Map(); ``` 上面的代码创建了一个新的空Map对象。我们可以使用set方法向Map对象添加新的键值对,例如: ``` map.set('name', '张三'); map.set('age', 18); ``` 上面的代码向Map对象中添加了两个键值对:'name'对应的值为'张三','age'对应的值为18。我们也可以使用get方法获取Map对象中的某个键对应的值,例如: ``` console.log(map.get('name')); // 输出:张三 console.log(map.get('age')); // 输出:18 ``` 上面的代码分别输出了Map对象中'name'和'age'对应的值。我们还可以使用has方法检查某个键是否存在于Map对象中,例如: ``` console.log(map.has('name')); // 输出:true console.log(map.has('gender')); // 输出:false ``` 上面的代码分别检查了Map对象中是否存在'name'和'gender'这两个键。我们还可以使用delete方法删除Map对象中的某个键值对,例如: ``` map.delete('age'); console.log(map.get('age')); // 输出:undefined ``` 上面的代码删除了Map对象中'age'对应的键值对,并使用get方法检查该键是否存在于Map对象中(输出结果为undefined,表示该键不存在)。 综上所述,Map对象提供了一种灵活的存储键值对的方式,可以方便地进行添加、删除、查找等操作。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨大大28

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值