JS中的new Map()方法介紹
在 JavaScript 中,Map
是一種新的數(shù)據(jù)結(jié)構(gòu),它與傳統(tǒng)的對(duì)象({}
)非常相似,用于存儲(chǔ)鍵值對(duì)(key-value pairs)。但是,Map
提供了更多的優(yōu)勢(shì)和功能,尤其是在鍵的處理上。本文將詳細(xì)介紹 new Map()
方法,如何使用它以及它相對(duì)于傳統(tǒng)對(duì)象的優(yōu)勢(shì)。
1. 什么是 Map?
Map
是 ES6 中新增的一個(gè)數(shù)據(jù)結(jié)構(gòu),它類似于對(duì)象,但它的鍵(key)可以是任何類型的值,而不僅限于字符串或符號(hào)。此外,Map
保持了鍵值對(duì)的插入順序,可以進(jìn)行遍歷操作。我們可以通過(guò) new Map()
來(lái)創(chuàng)建一個(gè)空的 Map
實(shí)例。
2. 創(chuàng)建一個(gè) Map
2.1 使用 new Map() 創(chuàng)建空的 Map
const map = new Map(); console.log(map); // Map(0) {}
通過(guò) new Map()
創(chuàng)建的是一個(gè)空的 Map
,此時(shí) map
中沒(méi)有任何鍵值對(duì)。
2.2 使用二維數(shù)組初始化 Map
你可以通過(guò)傳遞一個(gè)二維數(shù)組來(lái)初始化 Map
。數(shù)組的每個(gè)元素是一個(gè)包含兩個(gè)值的子數(shù)組,分別表示鍵和值。
const map = new Map([ ['name', 'John'], ['age', 30], ['city', 'New York'] ]); console.log(map); // Map(3) { 'name' => 'John', 'age' => 30, 'city' => 'New York' }
2.3 使用其他 Map 實(shí)例初始化
可以通過(guò)將一個(gè)已經(jīng)存在的 Map
實(shí)例作為參數(shù)來(lái)初始化另一個(gè) Map
:
const originalMap = new Map([ ['name', 'Alice'], ['age', 25] ]); const copiedMap = new Map(originalMap); console.log(copiedMap); // Map(2) { 'name' => 'Alice', 'age' => 25 }
3. Map 的常用方法
3.1 set(key, value)
set
方法用于向 Map
中添加或更新鍵值對(duì)。如果 Map
中已經(jīng)存在相同的鍵,那么它會(huì)更新該鍵對(duì)應(yīng)的值。
const map = new Map(); map.set('name', 'John'); map.set('age', 30); console.log(map); // Map(2) { 'name' => 'John', 'age' => 30 } map.set('name', 'Alice'); console.log(map); // Map(2) { 'name' => 'Alice', 'age' => 30 }
3.2 get(key)
get
方法用于根據(jù)給定的鍵獲取對(duì)應(yīng)的值。如果該鍵不存在,返回 undefined
。
const map = new Map(); map.set('name', 'John'); map.set('age', 30); console.log(map.get('name')); // John console.log(map.get('address')); // undefined
3.3 has(key)
has
方法檢查 Map
中是否包含給定的鍵,返回布爾值。
const map = new Map(); map.set('name', 'John'); console.log(map.has('name')); // true console.log(map.has('age')); // false
3.4 delete(key)
delete
方法用于刪除 Map
中指定鍵的鍵值對(duì),返回一個(gè)布爾值,表示刪除操作是否成功。
const map = new Map(); map.set('name', 'John'); map.set('age', 30); console.log(map.delete('name')); // true console.log(map.delete('address')); // false console.log(map); // Map(1) { 'age' => 30 }
3.5 clear()
clear
方法清空 Map
中所有的鍵值對(duì)。
const map = new Map(); map.set('name', 'John'); map.set('age', 30); map.clear(); console.log(map); // Map(0) {}
3.6 size
size
屬性返回 Map
中鍵值對(duì)的數(shù)量。
const map = new Map(); map.set('name', 'John'); map.set('age', 30); console.log(map.size); // 2
4. Map 的迭代方法
與傳統(tǒng)的對(duì)象不同,Map
可以很方便地進(jìn)行迭代。你可以通過(guò)多種方式遍歷 Map
,包括:
4.1 forEach 方法
forEach
方法用于遍歷 Map
中的每個(gè)鍵值對(duì),并對(duì)每一對(duì)進(jìn)行處理。
const map = new Map([ ['name', 'John'], ['age', 30] ]); map.forEach((value, key) => { console.log(`${key}: ${value}`); }); // 輸出: // name: John // age: 30
4.2 使用 for...of 迭代器
Map
支持 for...of
循環(huán),它會(huì)返回每個(gè)鍵值對(duì)。你可以使用解構(gòu)語(yǔ)法來(lái)直接訪問(wèn)鍵和值。
const map = new Map([ ['name', 'John'], ['age', 30] ]); for (const [key, value] of map) { console.log(`${key}: ${value}`); } // 輸出: // name: John // age: 30
4.3 keys(), values(), 和 entries()
Map
提供了三個(gè)方法來(lái)分別獲取所有的鍵、值和鍵值對(duì)。
keys()
返回一個(gè)包含所有鍵的迭代器。values()
返回一個(gè)包含所有值的迭代器。entries()
返回一個(gè)包含所有鍵值對(duì)的迭代器。
const map = new Map([ ['name', 'John'], ['age', 30] ]); console.log([...map.keys()]); // ['name', 'age'] console.log([...map.values()]); // ['John', 30] console.log([...map.entries()]); // [['name', 'John'], ['age', 30]]
5. Map 相對(duì)于傳統(tǒng)對(duì)象的優(yōu)勢(shì)
- 鍵的類型:在傳統(tǒng)的 JavaScript 對(duì)象中,鍵(key)必須是字符串或者符號(hào),而
Map
允許任何數(shù)據(jù)類型作為鍵(例如:對(duì)象、數(shù)組、函數(shù)等)。 - 保持插入順序:
Map
中的鍵值對(duì)是按插入順序進(jìn)行迭代的,而對(duì)象則沒(méi)有這一保證。 - 性能:對(duì)于頻繁的添加和刪除操作,
Map
通常比對(duì)象更高效,尤其是在大量數(shù)據(jù)的場(chǎng)景下。
6. 總結(jié)
Map
是 JavaScript 中非常強(qiáng)大的數(shù)據(jù)結(jié)構(gòu),它提供了比傳統(tǒng)對(duì)象更多的靈活性和功能。在你需要頻繁操作鍵值對(duì)的場(chǎng)景中,使用 Map
是一個(gè)更好的選擇,特別是在鍵可能不是字符串的情況下。通過(guò)本文的講解,相信你已經(jīng)能夠熟練地使用 Map
來(lái)處理各種需求。
到此這篇關(guān)于JS中的new Map()方法介紹的文章就介紹到這了,更多相關(guān)js new map方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
不提示直接關(guān)閉網(wǎng)頁(yè)窗口的JS示例代碼
本篇文章主要是對(duì)不提示直接關(guān)閉網(wǎng)頁(yè)窗口的JS示例代碼進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-12-12JavaScript中的finally()方法和Filter()方法詳解
finally是 JavaScript 構(gòu)造中使用的方法try-catch,Filter() 是 JavaScript 中的一種方法,可以通過(guò)處理數(shù)組輕松提供過(guò)濾后的輸出數(shù)據(jù),本文就給大家詳細(xì)的介紹一下JavaScript中的finally()方法和Filter()方法,需要的朋友可以參考下2023-08-08cocos2dx+lua實(shí)現(xiàn)橡皮擦功能
這篇文章主要為大家詳細(xì)介紹了cocos2dx+lua實(shí)現(xiàn)橡皮擦功能,類似刮刮樂(lè)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12JavaScript校驗(yàn)Number(4,1)格式的數(shù)字實(shí)例代碼
這篇文章主要介紹了JavaScript校驗(yàn)Number(4,1)格式的數(shù)字實(shí)例代碼,本文實(shí)現(xiàn)思路明確代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03checkbox全選所涉及到的知識(shí)點(diǎn)介紹
checkbox全選涉及到的知識(shí)點(diǎn)比如IE里起作用,火狐不起作用,getElementById()與getElementsByName()的區(qū)別等等2013-12-12silverlight線程與基于事件驅(qū)動(dòng)javascript引擎(實(shí)現(xiàn)軌跡回放功能)
前一段時(shí)間一直在重構(gòu)工作站軌跡回放功能,一開(kāi)始我覺(jué)得很簡(jiǎn)單,但是后面引發(fā)了一系列奇怪的問(wèn)題,讓我很疼,所以不得不寫(xiě)個(gè)總結(jié)加深記憶,2011-08-08DataTables添加額外的查詢參數(shù)和刪除columns等無(wú)用參數(shù)實(shí)例
下面小編就為大家?guī)?lái)一篇DataTables添加額外的查詢參數(shù)和刪除columns等無(wú)用參數(shù)實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07