ECMAScript-新的数据结构Map

一、ECMAScript-新的数据结构Set
1. 一种新的数据结构

结构类似于对象,键值对的集合。Map 结构提供了“值—值”的对应,是一种更完善的 Hash 结构实现。

let m = new Map()
let obj = { name: 'zhangsan'}
m.set('zhangsan', obj) 
2. 常用方法
// 添加
let m = new Map()
let obj = { name: 'zhangsan'}
m.set('zhangsan', obj) 

// 获取
m.get('zhangsan')

// delete
m.delete('zhangsan')

// has
m.has('zhangsan')

// 传入数组
let m = new Map([['name','zhangsan'],['age', 5]])
console.log(m)

// size
m.size

// 清空
m.clear()
3. 遍历
// forEach 
let m = new Map([['name','zhangsan'],['age', 5]])
// 第一个参数是value 
// 第二个参数是key
m.forEach(value, key) => {
  console.log(key + ' ' + value)
})
// for of
// 第一个参数是key
// 第二个参数是value
for(let [key, value] of m) {
    console.log(key + ' ' + value)
}

// map.keys()
// map.values()
// map.entries()
4. 应用场景
// 基本object应用到的场景,map都可以应用
// 尤其是在后端接口返回的数据,需要重新过滤组装的时候,map经常会被用到
5. WeakMap
// key 必须是引用数据类型
// WeakMap不支持clear
// WeakMap不可遍历
// WeakMap没有size
// 弱引用
let wm = new WeakMap()
wm.set([1,2,3], 'zhangsan')
©️2020 CSDN 皮肤主题: 技术工厂 设计师:CSDN官方博客 返回首页