1.一种内容不能重复的数据结构
2.常用方法
let s = new Set()
console.log(s)
let s = new Set([1, 2, 2, 3])
console.log(s)
//添加元素 支持链式结构
s.add('ada').add('rrr')
console.log(s)
//删除元素
s.delete(2)
console.log(s)
//判断是否包含某元素
console.log(s.has('rrr')) //bool
//长度
console.log(s.size)
//清空
s.clear()
console.log(s)
3.遍历
//第1种遍历方法
s.forEach(item => console.log(item))
//第2种遍历方法
for (let item of s.keys()) {
console.log(item)
}
//第3种遍历方法
for (let item of s.values()) {
console.log(item)
}
以上三种方法结果均如下图所示
//第4种遍历方法
for (let item of s.entries()) {
console.log(item)
}
由此可知,Set结构,key和value一样
4.应用场景
4.1数组去重
let arr = [1, 2, 2, 3, 3, 4, 5, 5]
let s = new Set(arr)
console.log(s)
4.2合并去重
let arr1 = [1, 2, 3, 4]
let arr2 = [2, 3, 4, 5, 6]
let s = new Set([...arr1, ...arr2])
console.log(s)
//得到数组
console.log([...s])
console.log(Array.from(s))
4.3交集
let arr1 = [1, 2, 3, 4]
let arr2 = [2, 3, 4, 5, 6]
let s1 = new Set(arr1)
let s2 = new Set(arr2)
let result = new Set(arr1.filter(item => s2.has(item)))
console.log(result)
4.4差集
let arr1 = [1, 2, 3, 4]
let arr2 = [2, 3, 4, 5, 6]
let s1 = new Set(arr1)
let s2 = new Set(arr2)
let arr3 = new Set(arr1.filter(item => !s2.has(item)))
let arr4 = new Set(arr2.filter(item => !s1.has(item)))
console.log([...arr3, ...arr4])
5.WeakSet
只能存储对象
let ws = new WeakSet()
ws.add(1)//报错 内容只能为对象
//添加
let obj1 = { name: 'aaa' }
let obj2 = { name: 'nnn' }
ws.add(obj1).add(obj2)
//删除
ws.delete(obj1)
//判断是否包含
console.log(ws.has(obj2)) //bool
//遍历 报错 不能被遍历 弱引用 不计入垃圾回收机制
//用于临时存储对象 当对象被释放,weakset中的引用也会消失
ws.forEach(item=>console.log(item))