我是靠谱客的博主 高大往事,这篇文章主要介绍JavaScript基础知识介绍——maps和sets,现在分享给大家,希望可以做个参考。

ES6引入了两个数据结构:maps和sets。maps跟对象类似,可用键(key)来map值(value)、sets则类似于数组,只不过不允许出现重复值

一、maps:

map对象将键和值映射起来的

example:

想把user对象映射到role的时候:

复制代码
1
2
3
4
const u1 = { name:"Cynthia"}; const u2 = { name:"Jackson"}; const u3 = { name:"James"};

从创建一个map对象开始:

复制代码
1
const userRole = new Map();

可以使用map中的set()方法把user赋给role:

复制代码
1
2
3
4
5
userRole //链式调用set()方法,节省打字时间 .set(u1,"User"); .set(u2,"User"); .set(u3,"Admin");

还可以给map的构造函数穿一个包含了数组的数组:

复制代码
1
2
3
4
5
6
const userRole = new Map([ [u1,"User"], [u2,"User"], [u3,"Admin"], ]);

如果想知道u2有什么role,可使用get()方法就行:

复制代码
1
2
userRole.get(u2); //"User"

如果调用的key在map中不存在,就会返回一个undefined。当然也可使用has()方法来查看map中是否包含给定的key:

复制代码
1
2
3
4
5
6
7
8
userRole.has(u1); //true userRole.get(u1); //"User" userRole.has(u3); //false userRole.get(u3); //undefined

如果key已经在map中了,那么调用set()后key对应的value就会被替换

复制代码
1
2
3
4
5
6
userRole.get(u1); //"User" userRole.set(u1,"Admin"); userRole.get(u1); //"Admin"

size属性返回map中的元素个数:

复制代码
1
2
userRole.size; //3

使用keys()方法可以拿到map中所有的键,values()可以拿到所有的值,entries()则可以以数组的方式获取键值对,数组中的第一个元素为键,第二个元素为值。所有这些方法都返回一个迭代的对象,从而用for...of循环来迭代

复制代码
1
2
3
4
5
6
7
for(let u of userRole.keys()) console.log(u.name); for(let u of userRole.values()) console.log(r); for(let u of userRole.entries()) //简写为:for(let [u,r] of userRoles) console.log('${u.name}:${r}');

如果需要一个数组(而不是一个可迭代的对象),可使用展开运算符:

复制代码
1
2
3
[...userRole.values()]; //["User","User","Admin"]

使用delete()方法可以删除map中的一个条目:

复制代码
1
2
3
userRole.delete(u2); userRole.size; //2

最后如果想删除map中的所有条目,可调用clear()方法:

复制代码
1
2
3
userRole.clear(); userRole.size; //0

二、Wake maps:

weak map跟Map在本质上是相同的,除了以下几点:

  • key必须是对象
  • WeakMap中的key可以被垃圾回收
  • WeakMap不能迭代或清空

WeakMap不能被迭代(因为在迭代中,暴露处于垃圾回收过程中的对象,是非常危险的,不会保留在内存)

正是因为WeakMap具备这些特性,才可以用它存储对象实例中的私有key

三、sets:

sets是一个不允许重复数据的集合

创建一个Set实例:

复制代码
1
const roles = new Set();

如果想添加一个user role,可用add()方法:

复制代码
1
2
roles.add("User"); //Set ["User"]

如果想把这个user编程管理员,急需调用add()方法:

复制代码
1
2
roles.add("Admin"); //Set ["User","Admin"]

跟Map一样,Set也有size属性:

复制代码
1
2
roles.size; //2

Set神奇之处:不需要再添加元素的时候中是否已有这个元素 ,如果添加早已存在于set中的值,什么都不会发生:

复制代码
1
2
3
4
roles.add("User"); //Set ["User","Admin"] roles.size; //2

删除roles,调用delete()方法即可,当它返回true的时候表示这个roles在set,否则返回false:

复制代码
1
2
3
4
5
6
roles.delete("Admin"); //true roles; //Set ["User"] roles.delete("Admin"); //false

四、Weak sets:

Weak Sets只能包含对象,这些对象可能会被垃圾回收。跟WeakMap类似,WeakSets中的值不能被迭代

Weak Sets的唯一用处就是判断给定对象是不是一个set

 

最后

以上就是高大往事最近收集整理的关于JavaScript基础知识介绍——maps和sets的全部内容,更多相关JavaScript基础知识介绍——maps和sets内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(62)

评论列表共有 0 条评论

立即
投稿
返回
顶部