zoukankan      html  css  js  c++  java
  • set/weakset map/weakset

    set/weakset  map/weakset

    set用法

    定义:是ES6的一种新的数据结构及(值的集合)

    Set跟其他数据结构不同的地方就在于:它的值不会有重复项。


    (1)使用:

    let set = new Set([13,3,4,5])
    set.add(3)
    // add添加元素 // 获取set中值的时候,需要先转成数组在取获取 // set里的元素是不会重复的

      

    (2)size属性  获取成员的个数。

        //数组的长度
        //length3
        console.log(set.size);//7
    

      

    (3)delete属性  用户删除Set结构中的指定值,删除成功返回:true,删除失败返回:fasle。

        //删除元素
        //pop
        //shift
    
        set.delete(32)
        console.log(set);
    

      

    (4)clear方法 清除所有成员

    //清空set
        set.clear();
        console.log(set);//set(0)
    

      

    (5) has方法 判断set结构中是否含有指定的值。如果有,返回true;如果没有,返回fasle。

        //判断是否存在
        console.log(set.has(1));//true
        console.log(set.has(32));//false
    

      

    (6) enteries 方法 返回一个键值对的遍历器。配合next使用

        let set = new Set([1, 2, 3, 3, 3, 22, 4, 44, 444])
       let set1 = set.entries();
        console.log(set1.next());
        console.log(set1.next());
        console.log(set1.next());
    
        console.log(set1.next());
        console.log(set1.next());
        console.log(set1.next());
    
    
        console.log(set.keys());
        console.log(set.values());
    

      

    (7)keys和values方法

    keys()方法:返回键名的遍历器。
    values()方法:返回键值的遍历器。

        console.log(set.keys());
        console.log(set.values());
    

      

    (8)foreach方法  遍历每一个成员。

        //通过foreach 遍历
        set.forEach(item=>{
            console.log(item);
        })
    

      

    WeakSet结构

    WeakSet结构同样不会存储重复的值,不同的是,它的成员必须是对象类型的值。

    WeakSet提供了add()方法,delete()方法,has()方法;

    不会有keys(),values(),entries(),forEach()等方法和size属性。

        let weakset = new WeakSet([{name:"a"},{age:10}]);//数组里的数据是对象
        console.log(weakset);
    

      

    map的用法:

    键值对的集合:

    使用   

    键可以是任何类型数据
        let map = new Map([["key","这个键"]]);
        console.log(map);
    
        console.log(map.get("key"));
    
    
        //键可以是任何类型数据
        //数字
        map.set(3,"数字键")
        console.log(map.get(3))
    
        //布尔类型
        map.set(true,"键是布尔");
        console.log(map.get(true));
    
        //对象
        let obj = { name: "aa" };
        map.set( obj ,"对象");
    
        //symbol
        let symbol = Symbol("键");
        map.set(symbol,"键是symbol");
    

      

    (1)set()方法  作用:给实例设置一对键值对,返回map实例。 使用如上代码。

    (2)get方法   作用:获取指定键名的键值,返回键值。   使用如上代码。

    (3)delete方法    作用:删除指定的键值对,删除成功返回:true,否则返回:false。

        //删除
        map.delete("key");// 键名
        //判断是否有指定键值对
    

      

    (4)clear 方法  作用:一次性删除所有键值对。

        //清空键值对
        map.clear()
        console.log(map)
    

      

    (5)has方法   作用:判断Map实例内是否含有指定的键值对,有就返回:true,否则返回:false。

        //判断是否有指定键值对
        console.log(map.has(3,"数字键"));
    

      

    (6)entries方法  作用:返回实例的键值对遍历器。

        // 使用entries遍历
        for (let [key, value] of map.entries()) {
            console.log(key + " " + value)
        }
    

      

    (7)keys和values方法 

    keys()方法:返回实例所有键名的遍历器。
    values()方法:返回实例所有键值的遍历器.

        //遍历键名
        for (let key of map.keys()) {
            console.log(key);
        }
        //遍历值
        for (let value of map.values()) {
            console.log(value);
        }
    

      

    (8)forEach方法

        map.forEach((value,key)=>{ console.log(key+":"+value)})
    

      

    (9)size方法

    size:获取实例的成员数

    Weak Map

    与Map不同点在于WeakMap结构的键名只支持引用类型的数据   比如:数组,对象,函数。

        let weakmap = new WeakMap([[{name:"aaa"}]])
        
        console.log(weakmap)
    

      

    同样WeakMap也拥有get、has、delete方法,用法和用途都一样。不同地方在于,WeakMap不支持clear方法,不支持遍历,也就没有了keys、values、entries、forEach

    这4个方法,也没有属性size。

  • 相关阅读:
    MySQL之----在java编程加强知识点
    走进windows编程的世界-----入门篇
    对Java、C#转学swift的提醒:学习swift首先要突破心理障碍。
    LeetCode--N-Queens
    美国人与欧洲人为什么都吃转基因食品?
    hdu1290
    OS 中文斜体 Italic Font Chinese
    为什么那些每三年跳一次槽的人越跳越好?
    [博弈] hdu 3683 Gomoku
    HDU 5358 First One(枚举)
  • 原文地址:https://www.cnblogs.com/wenaq/p/13610577.html
Copyright © 2011-2022 走看看