三分钟学习一下 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 3
6. values 办法 返回依照程序插入的每个元素的 value 值得迭代器对象
let test2 = myMap1.values()
for (let value of test2) {console.log(value)
}
// four two three
留神下面的打印程序,能够看到构造方法里先呈现的 key 在迭代对象里也先呈现,而不是有反复的话先删除再增加,而是反复的话间接笼罩对应的 value
7. set 办法 往 map 里插入或者笼罩对应的 key 和 value
myMap2.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: true
10. clear 办法 清空 map 对象 没啥好说的
myMap1.clear()
当然,很多场景下咱们用 object {}也能够实现 map 的性能,可细节上两者区别还是挺大的,尤其是在程序以及 key 的类型上。