React-Native小知识 set,map数据结构和for...of遍历

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实例的成员总数

实例的方法:
1.操作方法

add(value):添加某个值,返回Set结构本身。
delete(value):删除某个值,返回一个布尔值,表示删除是否成功。
has(value):返回一个布尔值,表示该值是否为Set的成员。
clear():清除所有成员,没有返回值

2.遍历方法

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) // true
m.delete(o) // true
m.has(o) // false
实例的属性

size属性返回Map结构的成员总数

实例的方法:
1.操作方式

set(key, value):设置key所对应的键值,然后返回整个Map结构(本身)
get(key):读取key对应的键值
has(key):返回一个布尔值,表示某个键是否在Map数据结构中
delete(key):删除某个键,返回布尔值
clear():清除所有成员,没有返回值

2.遍历方法

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循环会以任意顺序遍历键名

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.Set 基本用法 ES6提供了新的数据结构Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。Set本...
    雨飞飞雨阅读 5,837评论 0 7
  • 1. Set (1) 基本用法 ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复...
    __越过山丘__阅读 2,870评论 0 0
  • 基本用法 es6提供了新的数据结构Set,它类似于数组,但是他的成员值是唯一的,没有重复的值。Set本身就是一个构...
    曼珠沙华_521b阅读 2,662评论 0 0
  • 阴转晴。 早晨听了qzn的话,一起都没有去,很舒服的睡了一觉。醒来是被敲门声惊醒,她们来了之后继续睡觉。很冷,睡着...
    Cheryl_ak717阅读 2,286评论 0 0
  • 当我还是个孩子 你和我一样 是个笑容灿烂的孩子 当我拿鼻子靠近你 一口酸甜的空气 就永久的住进了身体 在那个热烘烘...
    慧海安地阅读 3,795评论 0 0