前端

new Set()

2020-12-10  本文已影响0人  你的bug由我造

基本用法

ES6提供了新的数据结构Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。

Set本身是一个构造函数,用来生成Set数据结构。

var arr = new Set()
[1, 2, 3, 4, 4].forEach(i => {
    arr.add(i)
})
// [1, 2, 3, 4]
for (let i of arr) {
  console.log(i)
}
// 1 2 3 4 
var set = new Set([1, 2, 3, 4, 4])
[...set]
// [1, 2, 3, 4]

可以看到Set结构不会添加重复的值。

Set函数可以接受一个数组(或类似数组的对象)作为参数,用来初始化。

// 例一
var set = new Set([1, 2, 3, 4, 4])
[...set]
// [1, 2, 3, 4]

// 例二
function divs () {
  return [...document.querySelectorAll('div')]
}
var set = new Set(divs())
set.size // 56

上面代码中,例一是Set函数接受数组作为参数,例二是接受类似数组的对象作为参数。

我们也可以利用set去做数组去重

var arr = [1, 2, 3, 4, 4]
[...new Set(arr)]

向Set加入值的时候,不会发生类型转换,所以5和"5"是两个不同的值。Set内部判断两个值是否不同,使用的算法叫做“Same-value equality”,它类似于精确相等运算符(===),主要的区别是NaN等于自身,而精确相等运算符认为NaN不等于自身。

let arr = new Set()
let a = NaN
let b = NaN
arr.add(a)
arr.add(b)
arr.size // 1

通过上面代码可以看到,在Set内部,两个NaN是相等。但是两个对象总是不相等的。

let arr = new Set()
let a = {}
let b = {}
arr.add(a)
arr.add(b)
arr.size // 2

Set实例的属性和方法

(1) size属性

size属性返回Set实例的成员总数

var set = new Set([1, 2, 3, 4])
set.size  // 4
(2) constructor属性

构造函数,默认就是Set函数。

(3) add(value)

添加某个值,返回Set结构本身

var set = new Set()
set.add(1).add(2)
set.size  // 1
(4) has(value)

返回一个布尔值,表示该值是否为Set的成员。

var set = new Set()
set.add(1)
set.has(1)  // true
set.has(2)  // false
(5) delete(value)

删除某个值,返回一个布尔值,表示删除是否成功。

var set = new Set()
set.add(1).add(2)
set.size // 2
set.delete(1)
set.size // 1
(6) clear()

清除所有成员,没有返回值。

var set = new Set()
set.add(1).add(2)
set.clear()
set.size // 0

遍历操作

Set结构的实例有四个遍历方法,可以用于遍历成员。

上一篇 下一篇

猜你喜欢

热点阅读