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

简介: 三分钟学习一下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)  /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的类型上。

相关文章
|
17天前
|
存储 JavaScript 索引
js开发:请解释什么是ES6的Map和Set,以及它们与普通对象和数组的区别。
ES6引入了Map和Set数据结构。Map的键可以是任意类型且有序,与对象的字符串或符号键不同;Set存储唯一值,无重复。两者皆可迭代,支持for...of循环。Map有get、set、has、delete等方法,Set有add、delete、has方法。示例展示了Map和Set的基本操作。
21 3
|
2天前
|
前端开发 JavaScript 索引
CSS常见用法 以及JS基础语法
CSS常见用法 以及JS基础语法
10 0
|
4天前
|
存储 JavaScript 前端开发
JavaScript对象方法详解
JavaScript对象方法详解
13 1
|
4天前
|
JavaScript 安全 前端开发
js的map函数
js的map函数
7 0
|
4天前
|
JavaScript
js多维数组去重并使具有相同属性的对象数量相加
js多维数组去重并使具有相同属性的对象数量相加
9 1
|
11天前
|
前端开发 JavaScript 数据安全/隐私保护
前端javascript的DOM对象操作技巧,全场景解析(二)
前端javascript的DOM对象操作技巧,全场景解析(二)
|
11天前
|
移动开发 缓存 JavaScript
前端javascript的DOM对象操作技巧,全场景解析(一)
前端javascript的DOM对象操作技巧,全场景解析(一)
|
11天前
|
缓存 编解码 自然语言处理
前端javascript的BOM对象知识精讲
前端javascript的BOM对象知识精讲
|
11天前
|
JavaScript 前端开发
JavaScript 日期对象
JavaScript 日期对象
|
11天前
|
存储 JavaScript 前端开发
JavaScript对象
JavaScript对象