三分钟学习一下JavaScript中map对象的用法
【三分钟学习一下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)/03. get方法 获取对应的value
console.log(myMap1.get(1)) // four4. has方法 判断是否含有对应的key
console.log(myMap1.has(1))// true5. 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和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: true10. clear方法清空map对象 没啥好说的
myMap1.clear()
当然,很多场景下我们用object {}也可以实现map的功能,可细节上两者区别还是挺大的,尤其是在顺序以及key的类型上。
推荐阅读
- WEB前端高级教程|web前端高级JavaScript - 关于变量提升this指向闭包作用域的一些练习题
- 前端|js vue base64 byte 转 为文件格式 (以excel为例)
- 三分钟学习一下JavaScript中set对象的用法
- vue|Vue.js响应式原理(三)——发布订阅模式和观察者模式
- vue|快速理解Vue 使用 vm.$set 解决对象新增属性不能响应的问题
- 每周知识总结|每周知识总结(五)
- 两个数组拿相同元素,数组去重,两个日期区间段合并
- javascript|基于jquery扩展漂亮的单选按钮——RadioButton
- js数组常用方法总结(二)map&forEach