new Set()

作者: 你的bug由我造 | 来源:发表于2020-12-10 11:47 被阅读0次

基本用法

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结构的实例有四个遍历方法,可以用于遍历成员。

  • keys():返回键名的遍历器
  • values():返回键值的遍历器
  • entries():返回键值对的遍历器
  • forEach():使用回调函数遍历每个成员

相关文章

  • ...new Set([])

    new Set实现去重 ...实现解构 let set =new Set(['a','b','c','a']); ...

  • 去重的hashset类似

    mySet: Set = new Set (); const mySet1 = new Set() mySet1...

  • es6 Set方法

    Set 集合 var s = new Set(); // 初始化一个空 Setvar s2 = new Set([...

  • new Set()

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

  • ...new Set([]) 与 [... copy]

    实现拷贝的两种方法:...new Set([])[... copy] 1,...new Set([]) 语法:.....

  • 简单的js去重

    new Set Array.from(new Set(arr)); 双重循环去重 filter去重

  • ES6 日常记录

    1. [...new set()] new set () 实现去重 ... 实现解构 https://es6.ru...

  • java常用方法

    java集合的方法:①Set set = new HashSet<>();②set.cont...

  • java常用方法

    java集合的方法:①Set set = new HashSet<>();②set.cont...

  • 数组去重的几个方法

    1 Array.from(new Set(arr)) [...new Set(arr)]2 for两层便利,和冒...

网友评论

    本文标题:new Set()

    本文链接:https://www.haomeiwen.com/subject/ivmlgktx.html