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);

        })
相关推荐
前端风云志1 分钟前
typescript结构化类型应用两例
javascript
杨进军20 分钟前
React 创建根节点 createRoot
前端·react.js·前端框架
ModyQyW35 分钟前
用 AI 驱动 wot-design-uni 开发小程序
前端·uni-app
说码解字41 分钟前
Kotlin lazy 委托的底层实现原理
前端
gnip1 小时前
总结一期正则表达式
javascript·正则表达式
爱分享的程序员1 小时前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘1 小时前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出1 小时前
万字长文带你了解微前端架构
前端·微服务·前端框架
你这个年龄怎么睡得着的1 小时前
为什么 JavaScript 中 'str' 不是对象,却能调用方法?
前端·javascript·面试
Java水解1 小时前
前端常用单位em/px/rem/vh/vm到底有什么区别?
前端