首页 > web前端 > js教程 > ES6中Set的用法介绍(代码示例)

ES6中Set的用法介绍(代码示例)

不言
发布: 2018-11-14 16:13:02
转载
2385 人浏览过

本篇文章给大家带来的内容是关于ES6中Set的用法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

概述

Set是一个新的数据结构,和其他语言的特性差不多,当然,作为js中的Set,他还是有一些属于js的特点。

初始化

new Set([iterable]);
登录后复制

初始化一个Set有一个可选的参数,这个参数必须是一个可迭代的对象,可迭代对象包括String、Array、Array-Like obejct(Arguments、NodeList)、Typped Array、Set、Map和用户定义的可迭代对象

字符串

new Set('1234') // Set(4) {"1", "2", "3", "4"}
登录后复制

数组

new Set([1,2,3,4]) // Set(4) {1, 2, 3, 4}
登录后复制

arguments

function sum(){
  return new Set(arguments)
}
sum(1,2,3,4)  // Set(4) {1, 2, 3, 4}
登录后复制

Set

new Set(new Set([1,2,3,4])) // Set(4) {1, 2, 3, 4}
登录后复制

添加值

初始化一个Set之后,可以继续往里面添加值

let set=new Set()
set.add(1)
set.add(1)
set.add(1)
console.log(set) // Set(1) {1}
登录后复制

借用这个特性可以搞很多事,比如过滤重复值

new Set([1,1,2,3]) // Set(3){1,2,3}
登录后复制

但是注意,两个相同的对象字面量是不同的对象,具有不同的引用,所以Set是无法将两个不同引用的对象标记为同一个的,即使他们看过去是一样的

let a={num:1}
let b={num:1}
console.log(a===b) //false
new Set(a, b)// Set(2){{num:1},{num:2}}
let c=a
console.log(c===a)//true
new Set(a,c)// Set(1){{num:1}}
登录后复制

判断是否包含

let set=new Set([1,2,3])
set.has(1) // true
set.has(4) //false
登录后复制

获取数量

let set=new Set([1,2,3])
set.size //3
登录后复制

删除

let set=new Set([1,2,3])
set.delete(1)// true
set.delete(1)// false
登录后复制

清空

let set=new Set([1,2,3])
set.clear()
console.log(set) // Set(0){}
登录后复制

遍历

let set=new Set([1,2,3])
set.forEach((s)=>{console.log(s)})
// 1
// 2
// 3
登录后复制

获取迭代器

let set=new Set([1,2,3])
let entries=set.entries()
console.log(entries.next().value) // [1,1]
console.log(entries.next().value) // [2,2]
console.log(entries.next().value) // [3,3]
console.log(entries.next().value) // undefined

for(let item of set){
    console.log(item)
}
// 1
// 2
// 3
登录后复制

获取键迭代器

let set=new Set([1,2,3])
let keys=set.keys()
console.log(keys.next().value) // 1
console.log(keys.next().value) // 2
console.log(keys.next().value) // 3
console.log(keys.next().value) // undefined

for(let {key} of set){
    console.log(key)
}
// 1
// 2
// 3
登录后复制

获取值迭代器

let set=new Set([1,2,3])
let values=set.values()
console.log(values.next().value) // 1
console.log(values.next().value) // 2
console.log(values.next().value) // 3
console.log(values.next().value) // undefined

for(let {value} of set){
    console.log(value)
}
// 1
// 2
// 3
登录后复制

以上是ES6中Set的用法介绍(代码示例)的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:segmentfault.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板