Set
# Set
ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。
# 基本语法
# 生成 Set 实例
定义一个空的 Set 实例。
let s = new Set()
1
在实例化的同时传入默认的数据。
let s = new Set([1, 2, 3, 4])
1
注意
初始化的参数必须是可遍历的,可以是数组或者自定义遍历的数据结构。
# 添加数据
s.add('hello')
s.add('goodbye')
1
2
2
或者
s.add('hello').add('goodbye')
1
注意
Set 数据结构不允许数据重复,所以添加重复的数据是无效的。
# 删除数据
删除数据分两种,一种是删除指定的数据,一种是删除全部数据。
// 删除指定数据
s.delete('hello') // true
// 删除全部数据
s.clear()
1
2
3
4
5
2
3
4
5
# 统计数据
Set 可以快速进行统计数据,如数据是否存在、数据的总数。
// 判断是否包含数据项,返回 true 或 false
s.has('hello') // true
// 计算数据项总数
s.size // 2
1
2
3
4
5
2
3
4
5
# 数组去重
去除数组中的重复元素。
let arr = [1, 2, 3, 4, 2, 3]
let s = new Set(arr)
console.log(s) // Set { 1, 2, 3, 4 }
1
2
3
2
3
# 合并去重
合并两数组,去除重复元素。
let arr1 = [1, 2, 3, 4]
let arr2 = [2, 3, 4, 5, 6]
let s = new Set([...arr1, ...arr2])
console.log(s) // Set { 1, 2, 3, 4, 5, 6 }
console.log([...s]) // [ 1, 2, 3, 4, 5, 6 ]
console.log(Array.from(s)) // [ 1, 2, 3, 4, 5, 6 ]
1
2
3
4
5
6
7
2
3
4
5
6
7
# 交集
取两个数组中相同的元素。
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(Array.from(result)) // [ 2, 3, 4 ]
1
2
3
4
5
6
7
2
3
4
5
6
7
# 差集
取两个数组中不同的元素。
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) // Set { 1 }
console.log(arr4) // Set { 5, 6 }
console.log([...arr3, ...arr4]) // [ 1, 5, 6 ]
1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
# 遍历方式
keys()
:返回键名的遍历器values()
:返回键值的遍历器entries()
:返回键值对的遍历器forEach()
:使用回调函数遍历每个成员for...of
:可以直接遍历每个成员
let s = new Set(['hello', 'goodbye'])
console.log(s.keys()) // SetIterator {'hello', 'goodbye'}
console.log(s.values()) // SetIterator {'hello', 'goodbye'}
console.log(s.entries()) // SetIterator {'hello' => 'hello', 'goodbye' => 'goodbye'}
s.forEach(item => {
console.log(item) // hello // goodbye
})
for (let item of s) {
console.log(item) // hello // goodbye
}
for (let item of s.keys()) {
console.log(item) // hello // goodbye
}
for (let item of s.values()) {
console.log(item) // hello // goodbye
}
for (let item of s.entries()) {
console.log(item[0], item[1]) // hello hello // goodbye goodbye
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# WeakSet
WeakSet 结构与 Set 类似,也是不重复的值的集合。但是,它与 Set 有三个区别:
- WeakSet 的成员只能是对象,而不能是其他类型的值。
let ws = new WeakSet()
ws.add(1)
// TypeError: Invalid value used in weak set
ws.add(Symbol())
// TypeError: invalid value used in weak set
1
2
3
4
5
2
3
4
5
let ws = new WeakSet()
const obj1 = {
name: 'imooc'
}
const obj2 = {
age: 5
}
ws.add(obj1)
ws.add(obj2)
ws.delete(obj1)
console.log(ws)
console.log(ws.has(obj2))
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
- WeakSet 没有
size
属性,没有办法遍历它的成员。 - WeakSet 中的对象都是弱引用,即垃圾回收机制不考虑 WeakSet 对该对象的引用,也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存,不考虑该对象还存在于 WeakSet 之中。
# 参考资料
(完)