我是靠谱客的博主 高大往事,最近开发中收集的这篇文章主要介绍JavaScript基础知识介绍——maps和sets,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

一、maps:

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

example:

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

const u1 = { name:"Cynthia"};
const u2 = { name:"Jackson"};
const u3 = { name:"James"};

从创建一个map对象开始:

const userRole = new Map();

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

userRole
//链式调用set()方法,节省打字时间
.set(u1,"User");
.set(u2,"User");
.set(u3,"Admin");

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

const userRole = new Map([
[u1,"User"],
[u2,"User"],
[u3,"Admin"],
]);

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

userRole.get(u2);
//"User"

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

userRole.has(u1);
//true
userRole.get(u1);
//"User"
userRole.has(u3);
//false
userRole.get(u3);
//undefined

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

userRole.get(u1);
//"User"
userRole.set(u1,"Admin");
userRole.get(u1);
//"Admin"

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

userRole.size;
//3

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

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}');

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

[...userRole.values()];
//["User","User","Admin"]

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

userRole.delete(u2);
userRole.size;
//2

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

userRole.clear();
userRole.size;
//0

二、Wake maps:

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

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

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

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

三、sets:

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

创建一个Set实例:

const roles = new Set();

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

roles.add("User");
//Set ["User"]

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

roles.add("Admin");
//Set ["User","Admin"]

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

roles.size;
//2

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

roles.add("User");
//Set ["User","Admin"]
roles.size;
//2

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

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所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部