JavaScript中Map和Set數(shù)據(jù)結(jié)構(gòu)使用方法詳解
一、Map
1. 定義與特點(diǎn)
Map 是 JavaScript ES6 中新增的一種數(shù)據(jù)結(jié)構(gòu),它類(lèi)似于對(duì)象,但比對(duì)象更強(qiáng)大、更靈活。Map是一種鍵值對(duì)集合,可以存儲(chǔ)任意類(lèi)型的鍵和值,與普通對(duì)象不同,Map保留了鍵的原始插入順序,并支持鏈?zhǔn)秸{(diào)用。Map的鍵可以是任何類(lèi)型的數(shù)據(jù),包括對(duì)象和函數(shù)。
2. 創(chuàng)建Map對(duì)象
使用
new Map()
構(gòu)造函數(shù)
使用字面量語(yǔ)法
const map = new Map(); const map = new Map([['key1', 'value1'], ['key2', 'value2']]);
3. 常用方法
添加鍵值對(duì):
set(key, value)
獲取鍵對(duì)應(yīng)的值:
get(key)
檢查鍵是否存在:
has(key)
刪除鍵值對(duì):
delete(key)
清空Map:
clear()
獲取Map大小:
size
map.set('key1', 'value1'); console.log(map.get('key1')); // 輸出: value1 console.log(map.has('key1')); // 輸出: true map.delete('key1'); map.clear(); console.log(map.size); // 輸出: 0(當(dāng)前Map中鍵值對(duì)的數(shù)量)
4. 遍歷Map
Map提供了多種遍歷方法:
forEach():遍歷Map中的每個(gè)鍵值對(duì),接受一個(gè)回調(diào)函數(shù)。
for...of方法:keys() :返回一個(gè)包含所有鍵的迭代器,values() :返回一個(gè)包含所有值的迭代器,entries() :返回一個(gè)包含所有鍵值對(duì)的迭代器。
const map = new Map([['key1', 'value1'], ['key2', 'value2']]); ? // 使用 forEach 方法遍歷 map.forEach((value, key) => { console.log(key, value); }); ? // 使用 for...of 循環(huán)遍歷 for (let [key, value] of map) { console.log(key, value); } ? // 使用 keys()、values() 和 entries() 方法遍歷 for (let key of map.keys()) { console.log(key); } ? for (let value of map.values()) { console.log(value); } ? for (let [key, value] of map.entries()) { console.log(key, value); }
5. Map與對(duì)象的區(qū)別
特性 | Map | 對(duì)象 |
---|---|---|
鍵的類(lèi)型 | 可以是任何數(shù)據(jù)類(lèi)型,包括對(duì)象、函數(shù)、基本類(lèi)型等 | 只能是字符串或符號(hào)類(lèi)型 |
鍵的順序 | 按插入順序保留鍵值對(duì) | 鍵的遍歷順序可能會(huì)根據(jù)不同的 JavaScript 引擎有所不同 |
大小屬性 | 有 size 屬性,可以直接獲取鍵值對(duì)的數(shù)量 | 沒(méi)有內(nèi)置的 size 屬性,需要手動(dòng)計(jì)算 |
迭代方式 | 可直接迭代,使用 for...of 循環(huán)或 forEach 方法 | 需要先獲取鍵數(shù)組,然后進(jìn)行迭代 |
默認(rèn)鍵 | 沒(méi)有默認(rèn)鍵 | 繼承自 Object.prototype ,可能會(huì)有默認(rèn)鍵 |
性能 | 在頻繁增刪鍵值對(duì)的操作中通常比對(duì)象更高效 | 適用于結(jié)構(gòu)化的靜態(tài)數(shù)據(jù) |
序列化/解析 | 沒(méi)有內(nèi)置的序列化或解析支持,但可以自定義實(shí)現(xiàn) | 可以使用 JSON.stringify 和 JSON.parse 進(jìn)行序列化和解析 |
創(chuàng)建方式 | 使用 new Map() 構(gòu)造函數(shù)或傳遞可迭代對(duì)象初始化 | 使用字面量語(yǔ)法 {} 或構(gòu)造函數(shù) new Object() 創(chuàng)建 |
方法 | 提供 set , get , has , delete , clear , keys , values , entries 等方法 | 提供 hasOwnProperty , in 運(yùn)算符等方法 |
二、Set
1. 定義與特點(diǎn)
Set 也是 JavaScript ES6 中新增的一種數(shù)據(jù)結(jié)構(gòu),它類(lèi)似于數(shù)組,但成員的值都是唯一的,沒(méi)有重復(fù)的值。Set內(nèi)部通過(guò)哈希算法保證元素的唯一性和快速查找。
2. 創(chuàng)建Set對(duì)象
使用
new Set()
構(gòu)造函數(shù)
使用字面量語(yǔ)法
const set = new Set(); const set = new Set([1, 2, 3, 4]);
3. 常用方法
添加元素:
add(value)
刪除元素:
delete(value)
檢查元素是否存在:
has(value)
清空Set:
clear()
獲取Set大小:
size
set.add(5); set.delete(5); console.log(set.has(5)); // 輸出: false set.clear(); console.log(set.size); // 輸出: 0(當(dāng)前Set中元素的數(shù)量)
4. 遍歷Set
Set提供了多種遍歷方法:
forEach():遍歷Set中的每個(gè)元素,接受一個(gè)回調(diào)函數(shù)。
for...of方法:keys():返回一個(gè)包含所有元素的迭代器(Set本身就是無(wú)序的,因此
keys()
和values()
返回的結(jié)果相同),values():返回一個(gè)包含所有元素的迭代器,entries():返回一個(gè)包含所有鍵值對(duì)的迭代器(Set中沒(méi)有鍵,因此返回的結(jié)果與values()
相同)。
const set = new Set([1, 2, 3, 4]); ? // 使用 forEach 方法遍歷 set.forEach((value) => { console.log(value); }); ? // 使用 for...of 循環(huán)遍歷 for (let value of set) { console.log(value); } ? // 使用 values()、keys() 和 entries() 方法遍歷 for (let value of set.values()) { console.log(value); } ? for (let key of set.keys()) { console.log(key); } ? for (let [key, value] of set.entries()) { console.log(key, value); }
5. 應(yīng)用場(chǎng)景
數(shù)據(jù)去重
Set
對(duì)象的一個(gè)核心用途是去除重復(fù)值。當(dāng)需要從數(shù)組中移除重復(fù)項(xiàng)時(shí),可以使用Set
來(lái)實(shí)現(xiàn)。
const numbers = [1, 2, 3, 4, 5, 5, 6, 6, 6]; const uniqueNumbers = new Set(numbers); console.log(uniqueNumbers); // 輸出: Set {1, 2, 3, 4, 5, 6}
這種用法在處理數(shù)據(jù)時(shí)非常常見(jiàn),特別是在需要確保集合中元素唯一性的情況下。
集合運(yùn)算
Set
對(duì)象支持多種集合運(yùn)算,包括交集、并集和差集。
const setA = new Set([1, 2, 3]); const setB = new Set([3, 4, 5]); const intersection = new Set([...setA].filter(x => setB.has(x))); console.log(intersection); // 輸出: Set {3}
通過(guò)這些運(yùn)算,可以方便地對(duì)集合進(jìn)行數(shù)學(xué)上的操作。
遍歷集合
Set
對(duì)象提供了多種方法來(lái)遍歷集合中的元素,例如forEach()
、values()
和keys()
等,這些方法使得遍歷和操作集合更加靈活。
const set = new Set([1, 2, 3]); set.forEach(value => console.log(value)); ? const values = Array.from(set.values()); console.log(values); // 輸出: [1, 2, 3] ? const keys = Array.from(set.keys()); console.log(keys); // 輸出: [1, 2, 3]
總結(jié)
到此這篇關(guān)于JavaScript中Map和Set數(shù)據(jù)結(jié)構(gòu)使用方法的文章就介紹到這了,更多相關(guān)JS中Map和Set數(shù)據(jù)結(jié)構(gòu)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)你了解多少
本篇文章主要介紹了js里面的==和===,== 判斷如果兩邊變量的類(lèi)型不同,而 === 則不做類(lèi)型轉(zhuǎn)換,有興趣的可以了解一下2017-07-07微信小程序?qū)崿F(xiàn)多行文字滾動(dòng)效果
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)多行文字滾動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03JavaScript使用indexOf獲得子字符串在字符串中位置的方法
這篇文章主要介紹了JavaScript使用indexOf獲得子字符串在字符串中位置的方法,涉及javascript中indexOf方法操作字符串的技巧,需要的朋友可以參考下2015-04-04JS實(shí)現(xiàn)的簡(jiǎn)單鼠標(biāo)跟隨DiV層效果完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)的簡(jiǎn)單鼠標(biāo)跟隨DiV層效果,涉及JavaScript基于時(shí)間函數(shù)動(dòng)態(tài)操作頁(yè)面元素屬性的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10JavaScript實(shí)現(xiàn)的開(kāi)關(guān)燈泡點(diǎn)擊切換特效示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的開(kāi)關(guān)燈泡點(diǎn)擊切換特效,涉及javascript事件響應(yīng)及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-07-07bootstrap datetimepicker日期插件超詳細(xì)使用方法介紹
本篇文章主要介紹了bootstrap datetimepicker日期插件超詳細(xì)使用方法介紹,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02JS調(diào)用頁(yè)面表格導(dǎo)出excel示例代碼
這篇文章主要介紹了JS調(diào)用頁(yè)面表格導(dǎo)出excel的具體實(shí)現(xiàn),需要的朋友可以參考下2014-03-03