const s=new Set(); [2,3,4,2,3,4,5,6,2,3,3].forEach(x=>s.add(x)) console.log(s); for(let i of s){ console.log(i) } console.log(s.add(9)); //add(value),添加某个值,返回Set结构本身 console.log(s.delete(2)); //删除某个值,返回一个布尔值,表示是否删除成功 console.log(s.has(2)); //返回一个布尔值,表示该值是否为set成员 console.log(s.clear()); //清楚所有成员,没有返回值 console.log(s);
//总结:ES6提供的新的数据结构Set.类似于数组,但是成员的值都是唯一的。set本身是一个构造函数,用来生成Set数据结构
//上面代码通过add()方法向Set结构加入成员,结果表明Set结构不会添加重复的值
// 去除数组重复成员 const list=[1,2,1,5,2,4,6,2,3,1,] console.log([...new Set(list)]);
// 去除字符串里面的重复字符 const str='gdfgdgdgarwefgsfsdf'; console.log([...new Set(str)]) //["g", "d", "f", "a", "r", "w", "e", "s"] console.log([...new Set(str)].join('')) //gdfarwes
//Object和Set在判断是否包含一个键上的写法不同
//对象的写法 const properties={ 'weight':1, 'height':1 }; if(properties['weight']){ //...... } //Set的写法 const properties1=new Set(); properties1.add('width') properties1.add('height') if(properties1.has('weight')){ //..... } //这又提供了一种数组去重的方法 function dedupe(array){ return Array.from(new Set(array)) } dedupe([11,1,2,3,2,3,4,5,3])
//Array.from方法可以将Set结构转为数组 const items=new Set([1,2,3,4,5,4,3,2]) console.log(items); //Set结构是entries键值对 const array=Array.from(items) console.log(array); [1,2,3,4,5]
// 遍历操作---四个 let set=new Set(['red','green','blue']) for(let item of set.keys()){ console.log(item); //red green blue } for(let item of set.values()){ console.log(item); //red green blue } for(let item of set.entries()){ console.log(item); //(2) ["red", "red"] (2) ["green", "green"] (2) ["blue", "blue"] }
// 总结---因为Set结构没有键名,只有键值,或者说键名和键值一样,所以keys和values方法的行为完全一致
// Set结构的实力默认可遍历,它的默认遍历器生成函数就是它的values方法
//forEach() let aa=new Set([1,24,9]) set.forEach((value,key)=>console.log(key +':' +value)) //11 //24:24 //9:9
//遍历
// 拓展运算符(...)内部使用for...of 循环,所以也可以用于Set结构;map 和filter 也可间接用于Set // 去除数组重复成员 const list1=[1,2,1,5,2,4,6,2,3,1,] console.log([...new Set(list1)]); //map let bb=new Set([1,2,3]) bb =new Set([...bb].map(x=>x*2)) console.log(bb); //返回Set结构 //filter let cc=new Set([1,6,10]) cc= new Set([...cc].filter(x=>(x%2)==0)) console.log(cc);
//注意:向Set加入值得时候,不会发生类型转变,所以5和'5'是两个不同的值;
// Set内部判断两个值是否相同,使用的算法类似于全等于运算符,主要的区别是向Set加入值时认为NaN等于自身,而全等于不认为。
// 两个空对象也会被视为两个值