欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的Map用法完全指南

 更新時間:2025年03月12日 11:25:16   作者:szial  
這篇文章主要介紹了JavaScript中Map用法的相關(guān)資料,通過實例講解了Map的創(chuàng)建、常用方法和迭代方式,還探討了Map與對象的區(qū)別,并通過一個例子展示了如何使用Map來統(tǒng)計字符出現(xiàn)的次數(shù),需要的朋友可以參考下

引言

在 JavaScript 中,Map 是一種用于存儲鍵值對的數(shù)據(jù)結(jié)構(gòu),具有靈活的鍵類型和豐富的方法。相較于傳統(tǒng)的對象(Object),Map 提供了更高效的鍵值對操作方式,特別適合處理大量數(shù)據(jù)和需要頻繁操作鍵值對的場景。本文將詳細介紹 Map 的創(chuàng)建、常用方法、迭代方式,并探討它與對象的區(qū)別和實際應(yīng)用場景。

1. 創(chuàng)建 Map

使用 new Map() 來創(chuàng)建一個空的 Map。

const map = new Map();

也可以在創(chuàng)建時初始化 Map,傳入一個包含鍵值對的數(shù)組:

const map = new Map([
  ["name", "Alice"],
  ["age", 25]
]);
console.log(map); // 輸出 Map(2) { 'name' => 'Alice', 'age' => 25 }

2. Map 和對象的對比

在學(xué)習(xí) Map 的基本操作之前,我們先來看一下 Map 與傳統(tǒng)對象的區(qū)別。

特性Map對象
鍵的類型任何類型(字符串、對象、函數(shù)等)只能是字符串或符號
插入順序保持插入順序不保證插入順序
鍵值對數(shù)量size 屬性手動計算(Object.keys().length
原型鏈污染有,繼承 Object.prototype
適用場景頻繁操作鍵值對,大量數(shù)據(jù)小規(guī)模鍵值對或需要方法時

通過對比可以看出,Map 在鍵的類型、插入順序的保持以及鍵值對操作的效率上,都有顯著的優(yōu)勢。

3. Map 的常用方法

3.1 set(key, value)

用于向 Map 添加一個鍵值對。如果鍵已經(jīng)存在,set 會更新其值。

map.set("name", "Bob");
map.set("age", 30);
console.log(map); // 輸出 Map(2) { 'name' => 'Bob', 'age' => 30 }

3.2 get(key)

獲取指定鍵的值,如果鍵不存在,返回 undefined

console.log(map.get("name")); // 輸出 'Bob'
console.log(map.get("gender")); // 輸出 undefined

3.3 has(key)

檢查 Map 中是否存在指定的鍵,返回 true 或 false。

console.log(map.has("name")); // 輸出 true
console.log(map.has("gender")); // 輸出 false

3.4 delete(key)

刪除指定的鍵值對,返回 true 如果成功刪除,否則返回 false。

map.delete("age");
console.log(map); // 輸出 Map(1) { 'name' => 'Bob' }

3.5 clear()

清空 Map,刪除所有鍵值對。

map.clear();
console.log(map); // 輸出 Map(0) {}

3.6 size

返回 Map 中鍵值對的數(shù)量。

map.set("name", "Alice");
map.set("age", 25);
console.log(map.size); // 輸出 2

4. Map 的迭代方法

Map 支持多種迭代方法,可以輕松遍歷其中的鍵值對。

4.1 forEach(callback)

遍歷 Map 中的每一個鍵值對,callback 函數(shù)接受三個參數(shù):值、鍵、Map 本身。

map.forEach((value, key) => {
  console.log(`${key}: ${value}`);
});
// 輸出:
// name: Alice
// age: 25

4.2 keys()

返回 Map 中所有鍵的迭代器(Iterator),可以用 for...of 來遍歷。

for (let key of map.keys()) {
  console.log(key);
}
// 輸出:
// name
// age

4.3 values()

返回 Map 中所有值的迭代器(Iterator)。

for (let value of map.values()) {
  console.log(value);
}
// 輸出:
// Alice
// 25

4.4 entries()

返回 Map 中所有鍵值對的迭代器,每個鍵值對會以 [key, value] 的形式返回。

for (let entry of map.entries()) {
  console.log(entry);
}
// 輸出:
// [ 'name', 'Alice' ]
// [ 'age', 25 ]

4.5 使用 for...of 遍歷 Map

可以直接用 for...of 遍歷 Map,默認會調(diào)用 entries() 方法,因此會返回 [key, value] 的數(shù)組。

for (let [key, value] of map) {
  console.log(`${key}: ${value}`);
}
// 輸出:
// name: Alice
// age: 25

5. Map 的應(yīng)用場景

Map 是一種適合存儲鍵值對的結(jié)構(gòu),尤其適用于以下場景:

  • 需要使用非字符串類型的鍵:對象的鍵只能是字符串或符號,而 Map 可以使用任意數(shù)據(jù)類型作為鍵,比如對象、函數(shù)等。

    const objKey = { id: 1 };
    const map = new Map();
    map.set(objKey, "Object as key");
    console.log(map.get(objKey)); // 輸出 'Object as key'
    
  • 需要頻繁操作鍵值對Map 在鍵值對的查找、插入、刪除操作上比對象性能更好,適合在頻繁操作鍵值對的場景下使用。

  • 需要保持插入順序Map 會按照插入的順序存儲鍵值對,因此在遍歷時順序是固定的,而對象則不保證插入順序。

  • 避免原型鏈污染:對象的鍵可能會受 Object.prototype 影響,而 Map 沒有原型鏈污染問題,可以安全地存儲任意鍵。

6. 使用 Map 統(tǒng)計字母出現(xiàn)的次數(shù)

我們可以通過一個例子來比較使用 Map 和不使用 Map 的差別。假設(shè)我們有一個字符串,需要統(tǒng)計其中每個字母出現(xiàn)的次數(shù)。Map 非常適合這種鍵值對存儲的場景。

方法 1:不用 Map,使用普通對象

function countLettersWithObject(str) {
  const letterCounts = {}; // 用對象存儲字母出現(xiàn)的次數(shù)

  for (let letter of str) {
    if (letterCounts[letter]) {
      letterCounts[letter]++;
    } else {
      letterCounts[letter] = 1;
    }
  }

  return letterCounts;
}

const result = countLettersWithObject("hello world");
console.log(result); // 輸出: { h: 1, e: 1, l: 3, o: 2, w: 1, r: 1, d: 1 }

方法 2:使用 Map

function countLettersWithMap(str) {
  const letterCounts = new Map(); // 用 Map 存儲字母出現(xiàn)的次數(shù)

  for (let letter of str) {
    if (letterCounts.has(letter)) {
      letterCounts.set(letter, letterCounts.get(letter) + 1);
    } else {
      letterCounts.set(letter, 1);
    }
  }

  return letterCounts;
}

const resultMap = countLettersWithMap("hello world");
console.log(resultMap); // 輸出: Map(7) { 'h' => 1, 'e' => 1, 'l' => 3, 'o' => 2, 'w' => 1, 'r' => 1, 'd' => 1 }

7. WeakMap 簡介

WeakMap 是 Map 的一種特殊類型,它的鍵必須是對象,且是弱引用(即不會阻止對象被垃圾回收)。如果某個對象在其他地方不再被引用,那么即使它是 WeakMap 的鍵,也會被垃圾回收,這樣可以防止內(nèi)存泄漏。

WeakMap 的特點

  • 只接受對象作為鍵,不支持基本類型。
  • 鍵是弱引用,不會阻止垃圾回收。
  • 沒有 size 屬性、clear 方法和遍歷方法(forEach、keysvalues、entries),因此不能遍歷 WeakMap

使用場景

WeakMap 通常用于私有屬性或私有數(shù)據(jù)的存儲,不希望這些數(shù)據(jù)影響垃圾回收。它適用于對象間的臨時映射關(guān)系,且在數(shù)據(jù)無需遍歷的情況下使用。

const weakMap = new WeakMap();
let obj = { id: 1 };

weakMap.set(obj, "some value");
console.log(weakMap.get(obj)); // 輸出 'some value'

obj = null; // 刪除對象的其他引用
// 在此之后,obj 被垃圾回收,WeakMap 中的鍵值對也會被清除

總結(jié)

Map 是一種強大的鍵值對數(shù)據(jù)結(jié)構(gòu),具有靈活的鍵類型支持、保持插入順序、豐富的內(nèi)置方法等優(yōu)勢,適合存儲和操作大量鍵值對。而 WeakMap 則是一種針對對象鍵的弱引用 Map,在特定場景中幫助管理內(nèi)存。希望這些內(nèi)容能幫助你全面理解和應(yīng)用 Map

到此這篇關(guān)于JavaScript中Map用法的文章就介紹到這了,更多相關(guān)JS中Map用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot整合Hutool實現(xiàn)文件上傳的使用示例

    SpringBoot整合Hutool實現(xiàn)文件上傳的使用示例

    文件上傳在項目經(jīng)常會用到,本文主要介紹了SpringBoot整合Hutool實現(xiàn)文件上傳的使用示例,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • mybatis源碼解讀之executor包懶加載功能?

    mybatis源碼解讀之executor包懶加載功能?

    這篇文章主要介紹了mybatis源碼解讀之executor包懶加載功能,mybatis的懶加載的實現(xiàn)由executor包的loader子包支持,下面文章詳細內(nèi)容需要的小伙伴可以參考一下
    2022-02-02
  • java抓取鼠標(biāo)事件和鼠標(biāo)滾輪事件示例

    java抓取鼠標(biāo)事件和鼠標(biāo)滾輪事件示例

    這篇文章主要介紹了java抓取鼠標(biāo)事件和鼠標(biāo)滾輪事件示例,需要的朋友可以參考下
    2014-05-05
  • Java多線程之FutureTask的介紹及使用

    Java多線程之FutureTask的介紹及使用

    之前介紹了線程池相關(guān)的對象,Runable Callable與Future,下面介紹FutureTask的作用,它的特性是怎樣的呢,需要的朋友可以參考下
    2021-06-06
  • 詳解SpringMVC攔截器配置及使用方法

    詳解SpringMVC攔截器配置及使用方法

    本篇文章主要介紹了SpringMVC攔截器配置及使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • PageHelper插件實現(xiàn)服務(wù)器端分頁功能

    PageHelper插件實現(xiàn)服務(wù)器端分頁功能

    這篇文章主要為大家詳細介紹了PageHelper插件實現(xiàn)服務(wù)器端分頁功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • SpringBoot中使用Swagger的超簡單方法

    SpringBoot中使用Swagger的超簡單方法

    大家一致認為springBoot使用swagger太麻煩了,每次都需要編寫config,今天小編告訴大家一種超簡單配置方法,教大家如何整合swagger,感興趣的朋友跟隨小編一起看看吧
    2021-07-07
  • 分析ThreadLocal內(nèi)存泄漏問題

    分析ThreadLocal內(nèi)存泄漏問題

    ThreadLocal的作用是提供線程內(nèi)的局部變量,這種變量在線程生命周期內(nèi)起作用,減少同一個線程內(nèi)多個函數(shù)或者組件之間一些公共變量傳遞的復(fù)雜度,但是如果濫用ThreadLocal可能會導(dǎo)致內(nèi)存泄漏,所以本文將為大家分析ThreadLocal內(nèi)存泄漏問題
    2023-07-07
  • Spring通過配置文件和注解實現(xiàn)屬性賦值

    Spring通過配置文件和注解實現(xiàn)屬性賦值

    這篇文章主要介紹了Spring通過配置文件和注解實現(xiàn)屬性賦值,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04
  • servlet 解決亂碼問題

    servlet 解決亂碼問題

    這篇文章主要介紹了servlet 解決亂碼問題 ,需要的朋友可以參考下
    2015-04-04

最新評論