ES6学习笔记(六)--set,map数据结构和for...of遍历
来源:互联网 发布:php程序员如何提高水平 编辑:程序博客网 时间:2024/05/21 11:26
Set
新的数据解构,成员值是唯一的
//不能添加相同的值var s = new Set();[2, 3, 5, 4, 5, 2, 2].map(x => s.add(x));for (let i of s) { console.log(i);}// 2 3 5 4//去除相同的值var set = new Set([1, 2, 3, 4, 4]);[...set]// [1, 2, 3, 4]
Set实例的属性和方法
实例的属性
Set.prototype.constructor
:构造函数,默认就是Set
函数Set.prototype.size
:返回Set
实例的成员总数
实例的方法:
操作方法
add(value)
:添加某个值,返回Set结构本身。delete(value)
:删除某个值,返回一个布尔值,表示删除是否成功。has(value)
:返回一个布尔值,表示该值是否为Set的成员。clear()
:清除所有成员,没有返回值
遍历方法
keys()
:返回一个键名的遍历器values()
:返回一个键值的遍历器entries()
:返回一个键值对的遍历器forEach()
:使用回调函数遍历每个成员
Map
JavaScript的对象(Object),本质上是键值对的集合(Hash结构),但是只能用字符串当作键
var m = new Map();var o = {p: "Hello World"};m.set(o, "content")m.get(o) // "content"m.has(o) // truem.delete(o) // truem.has(o) // false
实例的属性
size
属性返回Map结构的成员总数
实例的方法
操作方式
set(key, value)
:设置key所对应的键值,然后返回整个Map结构(本身)get(key)
:读取key对应的键值has(key)
:返回一个布尔值,表示某个键是否在Map数据结构中delete(key)
:删除某个键,返回布尔值clear()
:清除所有成员,没有返回值
遍历方法
keys()
:返回键名的遍历器values()
:返回键值的遍历器entries()
:返回所有成员的遍历器forEach()
:遍历Map的所有成员
for…of遍历
适用范围:数组、Set和Map结构、某些类似数组的对象(比如arguments对象、DOM NodeList对象)、Generator对象,以及字符串
与其他遍历语法比较
- for循环:写法麻烦
- forEach循环:无法中途跳出
- for…in
- 数组的键名是数字,但是for…in循环是以字符串作为键名“0”、“1”、“2”
- for…in循环不仅遍历数字键名,还会遍历手动添加的其他键,甚至包括原型链上的键
- 某些情况下,for…in循环会以任意顺序遍历键名
0 0
- ES6学习笔记(六)--set,map数据结构和for...of遍历
- ES6学习笔记(五)Set和Map数据结构
- ES6 —(Set 和 Map 数据结构)
- ES6学习笔记: Set和Map
- es6 set和map数据结构
- es6学习笔记Set和WeakSet数据结构
- ES6-Set 和 Map 数据结构(ECMAScript 6 入门笔记)
- es6学习(Set和Map)
- ES6学习之路~~数据结构:set和map
- ES6学习10章:Set和Map数据结构
- JavaScript学习笔记六:Map和Set
- ES6学习笔记(七)Iterator和for...of循环
- ECMAScript 6 学习系列课程 (ES6 Set和Map数据结构)
- 自学-ES6篇-Set和Map数据结构
- es6常见属性Set和Map数据结构
- ES6 -- 新的数据结构:Set和Map
- ES6的数据结构set 和 map
- es6新特性-Set和Map数据结构
- appledoc 使用方法
- SQL Server 2016新特性: Temporal table
- CSS3的nth-child() 和nth-of-type()选择器,表格奇偶行变色
- Java中的函数
- Android梳理 安装工具篇
- ES6学习笔记(六)--set,map数据结构和for...of遍历
- 自定义异常信息
- jacob操作office
- XML、JSON详解
- hadoop相关随记
- 安装RabbitMQ
- 数组
- YTU 3026: 中序线索化二叉树
- hdu5090(二分图,建图技巧)