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

TypeScript中Map與Set的區(qū)別小結(jié)

 更新時間:2025年10月10日 10:24:05   作者:心隨雨下  
TypeScript中Map和Set是兩種不同的集合類型,Map用于存儲鍵值對,支持任意類型鍵并保持插入順序,Set用于存儲唯一值,自動去重,兩者都提供高效的查找操作,下面就來詳細的介紹一下兩者的區(qū)別

在TypeScript中,Map和Set都是ES6引入的集合類型,它們有各自不同的用途和特性:

Map(映射)

Map是鍵值對的集合,其中鍵可以是任意類型(對象、函數(shù)、基本類型等)。

主要特性:

// 創(chuàng)建Map
const map = new Map<string, number>();

// 添加鍵值對
map.set('name', 'Alice');
map.set('age', 25);
map.set(1, 'one'); // 鍵可以是數(shù)字

// 獲取值
console.log(map.get('name')); // 'Alice'

// 檢查鍵是否存在
console.log(map.has('age')); // true

// 刪除鍵值對
map.delete('age');

// 獲取大小
console.log(map.size); // 2

Map的優(yōu)勢:

  • 鍵可以是任意類型
  • 保持插入順序
  • 有size屬性
  • 性能在頻繁增刪時更好

Set(集合)

Set是的集合,每個值在Set中只能出現(xiàn)一次。

主要特性:

// 創(chuàng)建Set
const set = new Set<number>();

// 添加值
set.add(1);
set.add(2);
set.add(2); // 重復(fù)值會被忽略
set.add(3);

// 檢查值是否存在
console.log(set.has(2)); // true

// 刪除值
set.delete(1);

// 獲取大小
console.log(set.size); // 2

// 遍歷
set.forEach(value => console.log(value));

Set的優(yōu)勢:

  • 自動去重
  • 快速判斷值是否存在
  • 保持插入順序

主要區(qū)別對比

特性MapSet
存儲內(nèi)容鍵值對唯一值
重復(fù)處理鍵唯一,值可重復(fù)值唯一
主要用途需要鍵值映射的場景需要唯一值的集合
查找性能通過鍵快速查找通過值快速查找
典型方法set(), get(), has()add(), has()

使用場景示例

Map使用場景:

// 用戶信息映射
const userMap = new Map<number, {name: string, email: string}>();
userMap.set(1, {name: 'Alice', email: 'alice@example.com'});
userMap.set(2, {name: 'Bob', email: 'bob@example.com'});

// 緩存數(shù)據(jù)
const cache = new Map<string, any>();

Set使用場景:

// 去重
const numbers = [1, 2, 2, 3, 3, 4];
const uniqueNumbers = new Set(numbers); // [1, 2, 3, 4]

// 標(biāo)簽集合
const tags = new Set<string>();
tags.add('javascript');
tags.add('typescript');
tags.add('javascript'); // 不會被重復(fù)添加

兩者都是TypeScript中非常有用的數(shù)據(jù)結(jié)構(gòu),根據(jù)具體需求選擇使用。

到此這篇關(guān)于TypeScript中Map與Set的區(qū)別小結(jié)的文章就介紹到這了,更多相關(guān)TypeScript Map Set內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • 比較精簡的Javascript拖動效果函數(shù)代碼

    比較精簡的Javascript拖動效果函數(shù)代碼

    比較精簡的Javascript拖動效果函數(shù)代碼...
    2007-07-07
  • 純javascript模仿微信打飛機小游戲

    純javascript模仿微信打飛機小游戲

    純JavaScript模仿微信打飛機游戲,做網(wǎng)頁小游戲的借鑒下,界面設(shè)計是豎長形仿手機屏幕風(fēng)格,游戲效果流暢,通過本篇文章給大家分享純js如何實現(xiàn)模仿微信打飛機小游戲,需要的朋友可以參考下
    2015-08-08
  • js文字滾動停頓效果代碼

    js文字滾動停頓效果代碼

    javascript文字滾動停頓效果的實現(xiàn)代碼
    2008-06-06
  • Javascript 獲取鼠標(biāo)當(dāng)前的位置實現(xiàn)方法

    Javascript 獲取鼠標(biāo)當(dāng)前的位置實現(xiàn)方法

    這篇文章主要介紹了Javascript 獲取鼠標(biāo)當(dāng)前的位置實現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • 微信小程序記住密碼的功能簡單幾步實現(xiàn)

    微信小程序記住密碼的功能簡單幾步實現(xiàn)

    軟件中的“記住密碼”選框不知道大家平時會不會勾選,反正對于一個重度懶癌患者的我來說就沒有不勾選的時候,畢竟隔一段時間就重新輸入一遍難記又難輸?shù)馁~號密碼,想想就讓人頭皮發(fā)麻。今天教大家用代碼在微信小程序中實現(xiàn)這個簡單的小功能
    2023-01-01
  • TypeError: Cannot set properties of undefined (setting ‘xx‘)的問題及解決方法

    TypeError: Cannot set properties of 

    這篇文章主要介紹了TypeError: Cannot set properties of undefined (setting ‘xx‘)的問題,本文給大家分享完美解決方案,需要的朋友可以參考下
    2023-09-09
  • JavaScript在Android的WebView中parseInt函數(shù)轉(zhuǎn)換不正確問題解決方法

    JavaScript在Android的WebView中parseInt函數(shù)轉(zhuǎn)換不正確問題解決方法

    這篇文章主要介紹了JavaScript在Android的WebView中parseInt函數(shù)轉(zhuǎn)換不正確問題解決方法,因轉(zhuǎn)換的字符串?dāng)?shù)字都以0開頭,導(dǎo)致parseInt函數(shù)在瀏覽器和Android WebView中轉(zhuǎn)換結(jié)果不一樣,本文給出了解決方法,需要的朋友可以參考下
    2015-04-04
  • JavaScript中Promise的then()方法用例詳解

    JavaScript中Promise的then()方法用例詳解

    在JavaScript中Promise是一種用于處理異步操作的編程模式,它代表了一個最終可能完成(解析)或失敗(拒絕)的操作及其結(jié)果值,這篇文章主要給大家介紹了關(guān)于JavaScript中Promise的then()方法用例的相關(guān)資料,需要的朋友可以參考下
    2025-07-07
  • 前端傳遞參數(shù)時form-data和json的區(qū)別詳解

    前端傳遞參數(shù)時form-data和json的區(qū)別詳解

    前端可以通FormData對象實現(xiàn)表單形式提交數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于前端傳遞參數(shù)時form-data和json區(qū)別的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • js+html5實現(xiàn)側(cè)滑頁面效果

    js+html5實現(xiàn)側(cè)滑頁面效果

    這篇文章主要為大家詳細介紹了js+html5實現(xiàn)側(cè)滑頁面效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評論