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

相关文章
|
27天前
|
Web App开发 JavaScript 前端开发
如何学习JavaScript?
如何学习JavaScript?
38 5
|
26天前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
23 2
|
26天前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
25 1
|
26天前
|
JavaScript 前端开发
JS中的构造函数的含义和用法
构造函数是JavaScript中用于创建新对象的特殊函数,通常首字母大写。通过`new`关键字调用构造函数,可以初始化具有相同属性和方法的对象实例,从而实现代码复用。例如,定义一个`Person`构造函数,可以通过传入不同的参数创建多个`Person`对象,每个对象都有自己的属性值。此外,构造函数还可以包含方法,使每个实例都能执行特定的操作。构造函数的静态属性仅能通过构造函数本身访问。ES6引入了`class`语法糖,简化了类的定义和实例化过程。
24 1
|
26天前
|
存储 JavaScript 前端开发
JavaScript学习第一章
本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
47 1
|
2月前
|
JavaScript 前端开发
JS try catch用法:异常处理
【10月更文挑战第12天】try/catch` 是 JavaScript 中非常重要的一个特性,它可以帮助我们更好地处理程序中的异常情况,提高程序的可靠性和稳定性。
26 1
|
2月前
|
JavaScript 前端开发 容器
js之dom学习
js之dom学习
46 0
|
2月前
|
存储 JavaScript 前端开发
js中map属性
js中map属性
23 0
|
5月前
|
存储 JavaScript 前端开发
|
JavaScript
js基础笔记学习247event对象3
js基础笔记学习247event对象3
68 0
js基础笔记学习247event对象3