ES6 从入门到精通 # 10:Set 集合数据类型

Posted 凯小默

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6 从入门到精通 # 10:Set 集合数据类型相关的知识,希望对你有一定的参考价值。

说明

ES6 从入门到精通系列(全23讲)学习笔记。

Set 集合

集合:表示无重复值的有序列表

let kaimo = new Set();
console.log(kaimo)

添加元素

let kaimo = new Set();
kaimo.add(3);
kaimo.add("1");
kaimo.add(3); 
kaimo.add([3, 1, 3])
console.log(kaimo)

删除元素

kaimo.delete([3, 1, 3]);
console.log(kaimo)
kaimo.delete(3);
console.log(kaimo)

校验某个值是否在 set 中

kaimo.has('1')

访问集合的长度

kaimo.size

注意:forEach 的用法,这里的 val 是相等于 key 的

kaimo.forEach((val, key) => 
	console.log("val--->", val)
	console.log("key--->", key)
)

用扩展运算符将集合转为数组

let kaimo = new Set([3, 1, 3]);
console.log(kaimo )
let arr = [...kaimo];
console.log(arr)

拓展

set 中对象的引用无法被释放

let kaimo = new Set(), obj = name: "kaimo313";
kaimo.add(obj)
// 释放当前的资源
obj = null
console.log(kaimo);

解决方法:使用 WeakSet

let kaimo1 = new Set(), obj1 = name1: "kaimo313";
kaimo1.add(obj1)
// 释放当前的资源
obj1 = null
let kaimo2 = new WeakSet(), obj2 = name2: "kaimo313";
kaimo2.add(obj2)
// 释放当前的资源
obj2 = null
kaimo1
kaimo2

WeakSet 的特点

  1. 不能传入非对象类型的参数

  1. 不可迭代

  1. 没有 forEach()
  2. 没有 size 属性

以上是关于ES6 从入门到精通 # 10:Set 集合数据类型的主要内容,如果未能解决你的问题,请参考以下文章

ES6 从入门到精通 # 11:Map 数据类型

ES6 从入门到精通 # 11:Map 数据类型

Rust从入门到精通12-集合

Python从入门到精通Python中的set集合(每个人都是唯一的个体)

Python从入门到精通Python中的set集合(每个人都是唯一的个体)

ES6 从入门到精通 # 02:let 和 const 命令