Web前端之路让前端飞前端开发

ES6之Set用法

2017-09-20  本文已影响693人  一二三kkxx

语法

set对象允许存储任何类型的唯一值,无论是原始值或者是对象引用;

new Set([iterable])

简述

set对象是值的集合,元素只会出现一次,即Set中的元素是唯一的.

set对象与数组之间的转换

var arr = [1,2,3,4,4];
var set = new Set(arr) //数组转换set对象
set //{1,2,3,4}
//方法一
Array.from(set) //[1,2,3,4]
//方法二
[...set] //[1,2,3,4]

set与字符串

var str = 'siiva';
new Set(str) //{'s','i','v','a'}

Set.prototype.add() && Set.prototype.size

mySet.add(value)

Set.prototype.size 返回Set实例的成员总数

Set.prototype.has()

has方法返回一个布尔值 来判断value是否存在Set对象中

mySet.has(value)

Set.prototype.delete()

delete() 方法可以从一个 Set 对象中删除指定的元素。

mySet.delete(value);

Set.prototype.clear()

用来清空一个Set对象中的所有元素

mySet.clear()

var mySet = new Set()
mySet.add(1).add('1')

mySet.size //2
mySet.has('1') //true

mySet.clear();

mySet.size //0

遍历器

Set.prototype.keys() : 返回键名的遍历器
Set.prototype.values():返回键值的遍历器
Set.prototype.entries(): 返回键值对的遍历器
Set.prototype.forEach() :回调函数遍历

var mySet = new Set(['s','i','v'])

for(let i of mySet.keys()){
console.log(i)
}
// s
// i
// v

for(let i of mySet.values()){
console.log(i)
}

// s
// i
// v

for(let i of mySet.entries()){
console.log(i)
}
// ['s','s']
// ['i','i']
// ['v','v']


var otherSet = mySet.entries();
otherSet.next().value // ['s','s']
otherSet // {'i','v'}
otherSet.next().value //['i','i']
otherSet // {'v'}
otherSet.next().value //['v','v']
otherSet // {}
mySet.entries(); // {"s", "i", "v"}

Set.prototype.forEach()

forEach 方法根据集合中元素的顺序,对每个元素都执行提供的 callback 函数一次。

mySet.forEach(callback[, thisArg])

已经被删除的元素,它是不会执行的,但是,undefined,null会执行

Set的一些用法

let arr1 = [1,2,3,4,5];
let arr2 = [4,5,6,7,8];
let a = new Set(arr1);
let b= new Set(arr2)

Weakset

WeakSet 对象允许你将弱保持对象存储在一个集合中,其中的每个对象值都只能出现一次.

无size属性,且WeakSet对象不可被遍历枚举;只能存储对象,不可放入字符串,数字等数据类型

方法有 WeakSet.prototype.add(value) / WeakSet.prototype.delete(value) / WeakSet.prototype.has(value)

上一篇下一篇

猜你喜欢

热点阅读