三分钟学习一下JavaScript中map对象的用法

上一篇文章花了几分钟工夫看了看set对象的应用,明天来写一些map对象的应用。两者的属性和办法差不多,老规矩,整体过一下。

1. 构造方法    let myMap1 = new Map([      [1, 'one'],      [2, 'two'],      [3, 'three'],      [1, 'four']    ])    let myMap2 = new Map()    2. size属性 获取元素个数 因为map的key不能雷同,雷同则会取前面的那个,所以myMap1的size为3    console.log(myMap1.size) // 3    console.log(myMap2.size)  /0    3. get办法 获取对应的value    console.log(myMap1.get(1)) // four    4. has办法 判断是否含有对应的key    console.log(myMap1.has(1))// true    5. keys 返回依照程序插入的每个元素的key值let test = myMap1.keys()for(let key of test){console.log(key)} // 1 ,2 36. values办法 返回依照程序插入的每个元素的value值得迭代器对象let test2 = myMap1.values()    for (let value of test2) {      console.log(value)}//  four two three留神下面的打印程序,能够看到构造方法里先呈现的key在迭代对象里也先呈现,而不是有反复的话先删除再增加,而是反复的话间接笼罩对应的value7. set办法 往map里插入或者笼罩对应的key和valuemyMap2.set(6,6)8. entries办法 返回蕴含[key,value]的迭代器对象const iterator1 = myMap1.entries()    for (const item of iterator1) {      console.log(typeof item, Array.isArray(item), item)}9. delete办法 删除对应的key 同时返回删除之前是否蕴含该元素const map1 = new Map();map1.set('bar', 'foo');console.log(map1.delete('bar'));// expected result: true10. clear办法  清空map对象 没啥好说的myMap1.clear()

当然,很多场景下咱们用object {}也能够实现map的性能,可细节上两者区别还是挺大的,尤其是在程序以及key的类型上。