美文网首页
Map 和 WeakMap 总结

Map 和 WeakMap 总结

作者: w晚风 | 来源:发表于2021-06-09 23:00 被阅读0次

    Map 类型特点和创建方式

    // map类型和obj类型的区别:对象的键只能是字符串类型,map的键名可以是各种类型
    let obj = {
      1: "李四",
      "1": "张三",
    };
    console.log(obj); // 张三
    
    // 声明Map类型
    let map = new Map();
    // 键名为字符串
    map.set("name", "李四");
    // 键名为数字
    map.set(1, "数字");
    // 键名为方法
    map.set(function() {}, "方法作为键名");
    // 对象键名
    map.set({}, "对象键名");
    console.log(map);
    

    Map 类型的增删改查

    map.set 增加
    map.delete(key) 删除单个
    map.clear() 删除全部
    map.get(key) 查询单个

    let map = new Map();
    // 增
    map.set("name", "李四");
    map.set("age", "10");
    
    // 删除
    // 单个删除,返回布尔值
    console.log(map.delete("age"));
    // 全部删除,没有返回值
    // map.clear()
    
    // 查询
    console.log(map.get("name")); // 李四
    
    console.log(map);
    
    

    遍历 Map 类型

    let map = new Map();
    map.set("name", "李四");
    map.set("age", "15");
    
    // 遍历所有的key
    console.log(map.keys());
    
    // 遍历所有的值
    console.log(map.values());
    
    // 遍历值和键
    console.log(map.entries());
    
    // for of 遍历键名
    for (let key of map.keys()) {
      console.log(key);
    }
    
    // for of 遍历值
    for (let val of map.values()) {
      console.log(val);
    }
    
    // 对象同时接收键和值
    for (let [key, val] of map.entries()) {
      console.log(key, val);
    }
    
    // forEach 遍历 map,第一个值是键值,第二个值是键名
    map.forEach((item, key) => {
      console.log(item, key);
    });
    
    

    Map 类型转换

    let map = new Map();
    map.set("name", "李四");
    map.set("age", "18");
    
    // 通过展开语法吧map变成数组
    console.log([...map]);
    
    let newmap = [...map];
    // filter过滤map中的键值为李四的值
    let newarr = newmap.filter((item) => {
      return item[1].includes("李四");
    });
    // 再用map接收过滤后的值
    let map2 = new Map(newarr);
    // 通过展开语法得到对应的key值
    console.log(...map2.keys());
    
    

    Map 类型操作 DOM 节点

    <div name="非常棒">songzhengxiang</div>
    <div name="这都被你发现了">千万别点我</div>
    
    // 声明map变量
    let map = new Map();
    // 遍历所有div元素
    let divs = document.querySelectorAll("div");
    
    divs.forEach((item) => {
      map.set(item, {
        name: item.getAttribute("name"),
      });
    });
    
    // 第一个是键值,第二个是键名
    map.forEach((content, divitem) => {
      divitem.addEventListener("click", () => {
        alert(content.name);
      });
    });
    console.log(map);
    

    Map 控制表单提交

    <form action="" onsubmit="return post()">
      服务协议
      <input type="checkbox" error="请勾选协议" />
      权限管理
      <input type="checkbox" error="请勾选权限管理" />
    
      <input type="submit" value="提交" />
    </form>
    
    
    function post() {
      // 获取所有多选款
      let error = document.querySelectorAll("[error]");
      let map = new Map();
      error.forEach((item) => {
        map.set(item, {
          error: item.getAttribute("error"),
          state: item.checked,
        });
      });
      let newmap = [...map];
      // every判断数组中的元素是否全部符合条件,全部符合返回true,有一个不符合返回false
      return newmap.every(
        ([div, checkbox]) => checkbox.state || alert(checkbox.error)
      );
    }
    
    

    WeakMap 的使用

    WeakMap 对象是一组键 / 值对的集合,其中的键是弱引用的。其键必须是对象,而值可以是任意的

    let weakmap = new WeakMap();
    const o1 = {};
    const o2 = function() {};
    weakmap.set(o1, "37");
    weakmap.set(o2, undefined);
    // weakmap.set("name","李四") // 报错
    console.log(weakmap);
    
    

    WeakMap 弱引用类型体验

    let obj = {
      name: "lisi",
    };
    let weakmap = new WeakMap();
    weakmap.set(obj, "lisi");
    // 打印出结果可以看到里面有值,但是点开里面是没有值得
    console.log(weakmap);
    obj = null;
    
    console.log(weakmap);
    
    setTimeout(() => {
      // 倒计时一秒后再打印结果为空
      console.log(weakmap);
    }, 1000);
    
    
    作者: https://szxio.gitee.io/hexoblog/JavaScript/Map/

    相关文章

      网友评论

          本文标题:Map 和 WeakMap 总结

          本文链接:https://www.haomeiwen.com/subject/alvyeltx.html