ES6基础----Map的使用

目录

[Map 是 Es6 新增的数据结构,主要用于存储键值对](#Map 是 Es6 新增的数据结构,主要用于存储键值对)

[1、size 属性返回 Map 的长度](#1、size 属性返回 Map 的长度)

[2、set() 方法用于向 Map 中写入内容 ---键可以用字符串或者用其他数据类型,但是 Object 只能是字符串](#2、set() 方法用于向 Map 中写入内容 ---键可以用字符串或者用其他数据类型,但是 Object 只能是字符串)

[3、get() 方法用于得到对应的值](#3、get() 方法用于得到对应的值)

[4、delete() 方法删除对应的元素 ---返回布尔值](#4、delete() 方法删除对应的元素 ---返回布尔值)

[5、has() 方法判断某个元素是否在 Map 中 --返回布尔值](#5、has() 方法判断某个元素是否在 Map 中 --返回布尔值)

[6、 clear() 清除 Map 中的全部内容 --返回所有值,没值返回undefined](#6、 clear() 清除 Map 中的全部内容 --返回所有值,没值返回undefined)

[7、 keys() 遍历得到键值](#7、 keys() 遍历得到键值)

[8、 values() 遍历得到值](#8、 values() 遍历得到值)

[9、entries() 遍历得到键值对](#9、entries() 遍历得到键值对)

[10、 forEach() 遍历得到 Map 所有值](#10、 forEach() 遍历得到 Map 所有值)


Map 是 Es6 新增的数据结构,主要用于存储键值对

// Object 提供 字符串--值

// Map 提供 值--值

复制代码
 let map = new Map();

console.log(map);//Map(0) {size: 0}

1、size 属性返回 Map 的长度

复制代码
 console.log(map.size);//0

2、set() 方法用于向 Map 中写入内容 ---键可以用字符串或者用其他数据类型,但是 Object 只能是字符串

复制代码
//                           键     值

        console.log(map.set("name","张三"));//Map(1) {'name' => '张三'}

        console.log(map.set("age",100));//Map(2) {'name' => '张三', 'age' => 100}

        console.log(map.set("address","昆明"));//Map(3) {'name' => '张三', 'age' => 100, 'address' => '昆明'}

        console.log(map.set(100,"昆明"));//Map(4) {'name' => '张三', 'age' => 100, 'address' => '昆明', 100 => '昆明'}

3、get() 方法用于得到对应的值

复制代码
console.log(map.get(100));//昆明

console.log(map.get("name"));//张三

console.log(map);//Map(4) {'name' => '张三', 'age' => 100, 'address' => '昆明', 100 => '昆明'}

4、delete() 方法删除对应的元素 ---返回布尔值

复制代码
console.log(map.delete(100));//true

console.log(map);//Map(3) {'name' => '张三', 'age' => 100, 'address' => '昆明'}

5、has() 方法判断某个元素是否在 Map 中 --返回布尔值

复制代码
console.log(map.has(100));//false

console.log(map.has("name"));//true

6、 clear() 清除 Map 中的全部内容 --返回所有值,没值返回undefined

复制代码
console.log(map.clear());//undefined   ---打印清除后的值

遍历取值

7、 keys() 遍历得到键值

复制代码
// console.log(map.keys());//MapIterator {'name', 'age', 'address'}   ---拿到对象的模式的键值

        for(let i of map.keys()){       //--取单独的值

            console.log(i);// name  age  address

        }

8、 values() 遍历得到值

复制代码
//  console.log(map.values());//MapIterator {'张三', 100, '昆明'}   ---拿到对象的模式的键值

        for(let i of map.values()){

            console.log(i); // 张三 100 昆明

        }

9、entries() 遍历得到键值对

复制代码
//  console.log(map.entries());//MapIterator {'name' => '张三', 'age' => 100, 'address' => '昆明'}   ---拿到对象的模式的键值

        for(let [i,y] of map.entries()){

            console.log(i,y);//  name 张三    age 100    address 昆明

        }

10、 forEach() 遍历得到 Map 所有值

复制代码
//只得到值

        map.forEach((a)=>{

            console.log(a);

        })


 //得到键和值

//                  值-键名

        map.forEach((a,b)=>{

            console.log(a,b);

        })
相关推荐
韭菜炒大葱几秒前
前端经典面试题:从 URL 输入到页面展示,中间经历了什么?
前端·http·面试
swipe8 分钟前
纯函数、柯里化与函数组合:从原理到源码,构建更可维护的前端代码体系
前端·javascript·面试
远山枫谷9 分钟前
uniapp + Vue 自定义组件封装:自定义样式从入门到实战
前端·vue.js
Lee川13 分钟前
JavaScript 中的 `this` 与变量查找:一场关于“身份”与“作用域”的深度博弈
前端·javascript·面试
Kakarotto3 小时前
Canvas 直线点击事件处理优化
javascript·vue.js·canvas
顺遂3 小时前
基于Rokid CXR-M SDK的引导式作业辅导系统设计与实现
前端
代码搬运媛3 小时前
Generator 迭代器协议 & co 库底层原理+实战
前端
前端拿破轮3 小时前
从0到1搭建个人网站(三):用 Cloudflare R2 + PicGo 搭建高速图床
前端·后端·面试
功能啥都不会3 小时前
PM2 使用指南 - 踩坑记录
前端
HelloReader3 小时前
React 中 useState、useEffect、useRef 的区别与使用场景详解,终于有人讲明白了
前端