深入理解ES6之—set与map
Set是无重复值的有序列表。Set会自动移除重复的值,因此你可以使用它来过滤数组中重复的值并返回结果。
Map是有序的键值对,其中的键允许是任何类型。
Set和Map是es6新增的两个数据集合。
Set集合
es6新增了set类型,这是一种无重复值的有序列表。Set允许对它包含的数据进行快速访问。
创建Set并添加项目
Set通过new Set()来创建,调用add()方法就可以向Set中添加项目。检查size属性还能查看其中包含多少项。
let set = new Set();
set.add(5);
set.add("5");
console.log(set.size);//2
Set不会使用强制类型转换来判断值是否重复。还可以向Set添加多个对象,他们不会被合并为同一项。
let set = new Set();
let key1 = {};
let key2 = {};
set.add(key1);
set.add(key2);
console.log(set.size);//2
如果add()方法用相同的值进行了多次调用,那么在第一次之后的调用实际上会被忽略。
let set = new Set();
set.add(5);
set.add("5");
set.add(5);//被忽略
console.log(set.size);//2
你可以使用数组来初始化一个Set,并且Set构造器确保不会重复使用这些值。
let set = new Set([1,2,3,4,5,2,6,5,5,5]);
console.log(set.size);//6
虽然数值5在数组中出现了四次,但是Set中只有一个5
你可以使用has()方法来测试某个值是否存在于set中
let set = new Set();
let key1 = {};
let key2 = {};
let key3 = {};
set.add(key1);
set.add(key2);
console.log(set.has(key1));//true
console.log(set.has(key3));//false
移除值
使用delete()方法来移除单个值或者调用clear()方法将所有值从Set中移除。
let set = new Set([1, 2, 3, 4, 5, 2, 6, 5, 5, "5"]);
console.log(set);
set.delete(5);
console.log(set.has(5));//false
set.clear();
console.log(set.size);//0
Set 上的forEach()方法
forEach()方法还会被传递一个回调函数,该回调函数接收三个参数:
- Set中下个位置的值
- 与第一个参数相同的值
- 目标Set本身
由于Set没有键,为了使forEach方法与数组和map的forEach方法一致:将Set中的每一项同时认定为键与值。
let set = new Set([1, 2]);
set.forEach(function(value, key, ownerSet) {
console.log(`${key} ${value}`)
console.log(ownerSet === set);
})
将Set转换为数组
let arr = [1,2,4,3,2,5,5];
let set = new Set(arr);
let arr1 = [...set];
console.log(arr1);
Map集合
ES6的Map类型是键值对的有序列表,而键和值都可以是任意类型。键的比较使用的是Object.is(),因此你可以将5与“5”同时作为键,因为他们类型不同。
可以调用set方法并传递一个键与一个关联的值,来给Map添加项;此后使用键名来调用get()方法便能提取对应的值。
let map = new Map();
map.set("name", "cc");
map.set("age", 23);
console.log(map.get("name"));//cc
console.log(map.get("age"));//23
也可以使用对象作为键
let map = new Map();
let key1 = {};
let key2 = {};
map.set(key1, 5);
map.set(key2, 8);
console.log(map.get(key1));//5
console.log(map.get(key2));//8
Map的方法和属性
- has(key)
- delete(key)
- clear()
- size
Map的初始化
你能将数组传递给Map构造器,以便使用数据来初始化一个Map。该数组中的每一项也必须是数组,内部数组的首个项会作为键,第二项则为对应值。因此整个Map就被这些双项数组填充。
let map = new Map([
["name", "cc"],
["age", 26]
]);
console.log(map.has("name"));//true
console.log(map.get("name"));//cc
console.log(map.has("age"));//true
console.log(map.get("age"));//26
console.log(map.size);//2
Map上的forEach()方法
let map = new Map([
["name", "cc"],
["age", 26]
]);
map.forEach(function(value, key, source) {
console.log(`${key}的值是${value}`);
console.log(source === map);
})
深入理解ES6之—set与map的更多相关文章
- 理解Golang哈希表Map的元素
目录 概述 哈希函数 冲突解决 初始化 结构体 字面量 运行时 操作 访问 写入 扩容 删除 总结 在上一节中我们介绍了 数组和切片的实现原理,这一节会介绍 Golang 中的另一个集合元素 - 哈希 ...
- 理解 ES6 Generator-next()方法
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 前端笔记之React(六)ES6的Set和Map&immutable和Ramda和lodash&redux-thunk
一.ES6的Set.Map数据结构 Map.Set都是ES6新的数据结构,都是新的内置构造函数,也就是说typeof的结果,多了两个: Set 是不能重复的数组 Map 是可以任何东西当做键的对象 E ...
- 前端知识体系:JavaScript基础-原型和原型链-理解 es6 中class构造以及继承的底层实现原理
理解 es6 中class构造以及继承的底层实现原理 原文链接:https://blog.csdn.net/qq_34149805/article/details/86105123 1.ES6 cla ...
- 【读书笔记】【深入理解ES6】#7-Set集合和Map集合
ES6新标准中将Set集合和Map集合添加到JS中. ES5中Set集合和Map集合 在ES5中,开发者们用对象属性来模拟这两种集合. var set = Object.create(null); s ...
- ES6之Set与Map加深理解
Set 类似于数组,但是成员的值都是唯一的,没有重复的值,有序. Set函数可以接受一个数组(或者具有 iterable 接口的其他数据结构)作为参数,用来初始化. 用途 数组去重: [...new ...
- 深入理解es6(下)
一.symbol javascript基本数据类型: null.undefined.number.boolean.string.symbol ES6 引入了一种新的原始数据类型Symbol,表示独一无 ...
- 深入理解ES6(二)(解构赋值)
变量的解构赋值 (1) 数组的解构赋值 1.基本用法 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring ). 只要等号两边的模式相同,左边的变量 ...
- es6之set和map
1.set ES6提供了新的数据结构Set.它类似于数组,但是成员的值都是唯一的,没有重复的值,set本身就是构造函数,所以可以通过new的方式来创建对象 // 例一 可以做数组去重用 var set ...
随机推荐
- hdu1356&hdu1944 博弈论的SG值(王道)
S-NimProblem DescriptionArthur and his sister Caroll have been playing a game called Nim for some ti ...
- Reshape the Matrix
In MATLAB, there is a very useful function called 'reshape', which can reshape a matrix into a new o ...
- 入门VMware Workstation下的Debian学习之基本命令(二)
本章记录如何在Linux终端进行命令操作命令下载路径,模拟终端.dkpg管理软件包.用户组和用户管理.文件属性.文件与目录管理.查看磁盘使用量. (1)命令下载路径: wegt 路径; (2)模拟终端 ...
- ch3-模板语法({{}} v-html v-bind:id 表达式 指令 修饰符 过滤器)
1 模板语法 Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据. 所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器 ...
- Elasticsearch学习笔记 一
本文版权归博客园和作者吴双本人共同所有 转载和爬虫请注明原文地址 www.cnblogs.com/tdws. 本文参考和学习资料 <ES权威指南> 一.基本概念 存储数据到ES中的行为叫做 ...
- 干了这杯Java之LinkedList
LinkedList和ArrayList一样实现了List接口 ArrayList内部为数组 LinkedList内外为双向链表 实现了Deque接口,双端列队的实现 图片来自Wiki 内部实现为No ...
- d3力导向图聚焦
效果描述 双击节点,节点以及节点一度关联的节点保持高亮状态,其余节点变灰,半径变小,文字消失,并且向内收缩. 效果展示 正常状态 聚焦效果 关键代码 节点变化 激活节点保持高亮的样式,其余节点应用no ...
- Python程序练习4--模拟员工信息数据库操作
1.功能简介 此程序模拟员工信息数据库操作,按照语法输入指令即能实现员工信息的增.删.改.查功能. 2.实现方法 架构: 本程序采用python语言编写,关键在于指令的解析和执行:其中指令解析主要 ...
- [ACdream] 女神教你字符串——三个气球
Problem Description 女神邀请众ACdream开联欢会,显然作为ACM的佼佼者,气球是不能少的~.女神准备了三种颜色的气球,红色,黄色,绿色(交通信号灯?) 有气球还不能满足女神,女 ...
- java swing中Timer类的学习
最近在完成学校课程的java平时作业,要实现一个计时器,包含开始.暂停以及重置三个功能.由于老师规定要用这个timer类,也就去学习了一下,顺便记录一下. 首先呢去查了一下java手册上的东西,发现t ...