es6学习-10
Set和WeakSet数据结构
这节学习Set数据结构,注意这里不是数据类型,而是数据结构。它是ES6中新的东西,并且很有用处。Set的数据结构是以数组的形式构建的。
Set的声明
let setArr = new Set(['jspang','技术胖','web','jspang']); console.log(setArr);//Set {"jspang", "技术胖", "web"}
Set和Array 的区别是Set不允许内部有重复的值,如果有只显示一个,相当于去重。虽然Set很像数组,但是他不是数组。
Set值的增删查
追加add:
在使用Array的时候,可以用push进行追加值,那Set稍有不同,它用更语义化的add进行追加。
let setArr = new Set(['jspang','技术胖','web','jspang']); console.log(setArr);//Set {"jspang", "技术胖", "web"} setArr.add('前端职场'); console.log(setArr);
删除delete:
let setArr = new Set(['jspang','技术胖','web','jspang']); console.log(setArr);//Set {"jspang", "技术胖", "web"} setArr.add('前端职场'); console.log(setArr); //Set {"jspang", "技术胖", "web", "前端职场"} setArr.delete('前端职场'); console.log(setArr); //Set {"jspang", "技术胖", "web"}
查找has:
用has进行值的查找,返回的是true或者false。
let setArr = new Set(['jspang','技术胖','web','jspang']); console.log(setArr);//Set {"jspang", "技术胖", "web"} console.log(setArr.has('jspang'));//true
删除clear:
let setArr = new Set(['jspang','技术胖','web','jspang']); console.log(setArr);//Set {"jspang", "技术胖", "web"} setArr.clear(); console.log(setArray);//true
set的循环
for…of…循环:
let setArr = new Set(['jspang','技术胖','web','jspang']); for (let item of setArr){ console.log(item); }
size属性
size属性可以获得Set值的数量。
let setArr = new Set(['jspang','技术胖','web','jspang']); for (let item of setArr){ console.log(item); } console.log(setArr.size);
forEach循环
let setArr = new Set(['jspang','技术胖','web','jspang']); setArr.forEach((value)=>console.log(value));
WeakSet的声明
let weakObj=new WeakSet(); let obj={a:'jspang',b:'技术胖'} weakObj.add(obj); console.log(weakObj);
这里需要注意的是,如果你直接在new 的时候就放入值,将报错。
WeakSet里边的值也是不允许重复的,我们来测试一下。
let weakObj=new WeakSet(); let obj={a:'jspang',b:'技术胖'} let obj1=obj; weakObj.add(obj); weakObj.add(obj1); console.log(weakObj);
总结:在实际开发中Set用的比较多,WeakSet用的并不多,但是他对传入值必须是对象作了很好的判断,我们灵活应用还是有一定的用处的。