zoukankan      html  css  js  c++  java
  • ES6 第十三节 Set和WeakSet数据结构

    ES6 第十三节 Set和WeakSet数据结构


    第十三节 Set和WeakSet数据结构

    Set数据结构(不是数据类型),是ES6中的新东西。它的数据结构是以数组的形式构建的。

    Set的声明

    let setArr = new (['da0sy','黛西','web','da0sy']);
    console.log(setArr);  
    

    Set和Array 的区别是Set不允许内部有重复的值,如果有只显示一个,相当于去重。虽然Set很像数组,但是它不是数组。

    Set的增删改

    追加add:
    在使用Array的时候,可以用push进行追加值,那Set稍有不同,它用更语义化的add进行追加。

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    console.log(setArr);  
    
    setArr.add('前端职场');
    console.log(setArr);
    

    删除delete:

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    console.log(setArr);
    
    setArr.add('前端职场');
    console.log(setArr);
    
    setArr.delete('前端职场');
    console.log(setArr);
    

    查找has:
    用has进行值的查找,返回的是true或者false。

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    console.log(setArr);
    
    console.log(setArr.has('da0sy'));  //true
    

    删除clear:

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    console.log(setArr);
    setArr.clear();
    
    console.log(setArr);  //0
    

    set的循环 fior...of...循环:

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    for(let item of setArr){
        console.log(item);
    }   //会去重
    

    size属性
    size属性可以获得Set值的数量。

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    for(let item of setArr){
        console.log(item);
    }
    console.log(setArr.size);  //3
    

    forEach循环

    let setArr = new Set(['da0sy','黛西','web','da0sy']);
    setArr.forEach((value)=>console.log(value));  //会去重
    

    WeakSet的声明

    let weakObj=new WeakSet();
    let obj={a:'da0sy',b:'黛西'};
    weakObj.add(obj);
    
    console.log(weakObj);
    

    这里需要注意的是,如果你直接在new 的时候就放入值,将报错。

    WeakSet里边的值也是不允许重复的,我们来测试一下。

    let weakObj=new WeakSet();
    let obj={a:'da0sy',b:'黛西'};
    let obj1=obj;
    
    weakObj.add(obj);
    weakObj.add(obj1);
    
    console.log(weakObj);
    

    总结:在实际开发中Set用的比较多,WeakSet用的并不多,但是他对传入值必须是对象作了很好的判断,我们灵活应用还是有一定的用处的。

  • 相关阅读:
    P3973 [TJOI2015]线性代数
    P3168 [CQOI2015]任务查询系统
    二次剩余学习笔记
    URL注入攻击+知识星球资源整理
    我的网络安全架构知识点的总结(待完善)
    Sudo提权
    DNSlog平台各种利用姿势(盲注)
    Wireshark抓包理论加实操
    Fofa搜索技巧(理论加实践的整理)
    Windows留后门维持权限(其中包括详细的telnet改端口与连接)
  • 原文地址:https://www.cnblogs.com/Elva3zora/p/12552954.html
Copyright © 2011-2022 走看看