es6学习-10

Posted 小凡的耿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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用的并不多,但是他对传入值必须是对象作了很好的判断,我们灵活应用还是有一定的用处的。

 

以上是关于es6学习-10的主要内容,如果未能解决你的问题,请参考以下文章

30秒就能看懂的JavaScript 代码片段

ES6学习-2 let

es6学习笔记

vue2.0 代码功能片段

ES6-10学习笔记

PHP必用代码片段