ES6中Set和Map數(shù)據(jù)結(jié)構(gòu)的簡單講解
Set
ES6 提供了新的數(shù)據(jù)結(jié)構(gòu) Set。它類似于數(shù)組,但是成員的值都是唯一的,沒有重復(fù)的值。 Set本身是一個(gè)構(gòu)造函數(shù),用來生成 Set 數(shù)據(jù)結(jié)構(gòu)。
const s = new Set(); [2, 3, 5, 4, 5, 2, 2].forEach(x => s.add(x)); for (let i of s) { console.log(i); } // 2 3 5 4
上面代碼通過add()方法向 Set 結(jié)構(gòu)加入成員,結(jié)果表明 Set 結(jié)構(gòu)不會添加重復(fù)的值。
去除數(shù)組的重復(fù)成員
[...new Set('ababbc')].join('') // "abc"
向 Set 加入值的時(shí)候,不會發(fā)生類型轉(zhuǎn)換,所以5和"5"是兩個(gè)不同的值。Set 內(nèi)部判斷兩個(gè)值是否不同,使用的算法叫做“Same-value-zero equality”,它類似于精確相等運(yùn)算符(===),主要的區(qū)別是向 Set 加入值時(shí)認(rèn)為NaN等于自身,而精確相等運(yùn)算符認(rèn)為NaN不等于自身。
Set 實(shí)例的屬性和方法 Set 結(jié)構(gòu)的實(shí)例有以下屬性。
Set.prototype.constructor:構(gòu)造函數(shù),默認(rèn)就是Set函數(shù)。
Set.prototype.size:返回Set實(shí)例的成員總數(shù)。
Set 實(shí)例的方法分為兩大類:操作方法(用于操作數(shù)據(jù))和遍歷方法(用于遍歷成員)。下面先介紹四個(gè)操作方法。
Set.prototype.add(value):添加某個(gè)值,返回 Set 結(jié)構(gòu)本身。
Set.prototype.delete(value):刪除某個(gè)值,返回一個(gè)布爾值,表示刪除是否成功。
Set.prototype.has(value):返回一個(gè)布爾值,表示該值是否為Set的成員。
Set.prototype.clear():清除所有成員,沒有返回值。
s.add(1).add(2).add(2); // 注意2被加入了兩次 s.size // 2 s.has(1) // true s.has(2) // true s.has(3) // false s.delete(2); s.has(2) // false
Array.from方法可以將 Set 結(jié)構(gòu)轉(zhuǎn)為數(shù)組。
const items = new Set([1, 2, 3, 4, 5]); const array = Array.from(items);
這就提供了去除數(shù)組重復(fù)成員的另一種方法。
function dedupe(array) { return Array.from(new Set(array)); } dedupe([1, 1, 2, 3]) // [1, 2, 3]
遍歷操作
Set 結(jié)構(gòu)的實(shí)例有四個(gè)遍歷方法,可以用于遍歷成員。
Set.prototype.keys():返回鍵名的遍歷器
Set.prototype.values():返回鍵值的遍歷器
Set.prototype.entries():返回鍵值對的遍歷器
Set.prototype.forEach():使用回調(diào)函數(shù)遍歷每個(gè)成員
需要特別指出的是,Set的遍歷順序就是插入順序。這個(gè)特性有時(shí)非常有用,比如使用 Set 保存一個(gè)回調(diào)函數(shù)列表,調(diào)用時(shí)就能保證按照添加順序調(diào)用。
附:應(yīng)用場景
1.數(shù)組去重
var arr = [1, 2, 3, undefined,undefined,null,null, NaN, 1, 2, 3, NaN], set = new Set(arr); console.log([...set]);
2. 數(shù)組去重后的實(shí)現(xiàn)映射數(shù)組
set實(shí)例本身沒有map,filter等數(shù)組屬性
let set = new Set([1,2,3,4,5,6,7]); let set2 = new Set([...set].map(value => value * 2)); let set = new Set([1,2,3]); let set1 = new Set(Array.from(set, vlaue=>value * 2));
數(shù)組去重后,過濾返回新的數(shù)組
let set = new Set([1,2,3,4,5,6,7,1,2,3]); let set2 = new Set([...set].filter(x => (x%2) == 0));
Map
JavaScript 的對象(Object),本質(zhì)上是鍵值對的集合(Hash 結(jié)構(gòu)),但是傳統(tǒng)上只能用字符串當(dāng)作鍵。這給它的使用帶來了很大的限制。
const map = new Map([ ['name', '張三'], ['title', 'Author'] ]); map.size // 2 map.has('name') // true map.get('name') // "張三" map.has('title') // true map.get('title') // "Author"
和Set 對比
Map.prototype上的clear()、has()、size、delete()方法與Set.prototype上相同;唯一不同的是,Set是不存在鍵名的,鍵值與鍵名相同,所以沒有g(shù)et和set的方法,只有add方法;而Map具有鍵名和鍵值,所以對應(yīng)set和get方法;
總結(jié)
到此這篇關(guān)于ES6中Set和Map數(shù)據(jù)結(jié)構(gòu)的文章就介紹到這了,更多相關(guān)ES6 Set和Map數(shù)據(jù)結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- ES6學(xué)習(xí)筆記之Set和Map數(shù)據(jù)結(jié)構(gòu)詳解
- ES6教程之for循環(huán)和Map,Set用法分析
- 一文搞懂ES6中的Map和Set
- ES6學(xué)習(xí)筆記之map、set與數(shù)組、對象的對比
- ES6新特性五:Set與Map的數(shù)據(jù)結(jié)構(gòu)實(shí)例分析
- 詳解ES6中的Map與Set集合
- ES6中Set和Map數(shù)據(jù)結(jié)構(gòu),Map與其它數(shù)據(jù)結(jié)構(gòu)互相轉(zhuǎn)換操作實(shí)例詳解
- ES6中Set和Map用法實(shí)例詳解
相關(guān)文章
JS腳本實(shí)現(xiàn)動態(tài)給標(biāo)簽控件添加事件的方法
這篇文章主要介紹了JS腳本實(shí)現(xiàn)動態(tài)給標(biāo)簽控件添加事件的方法,結(jié)合實(shí)例形式分析了javascript添加事件監(jiān)聽的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-06-06深入了解Javascript的事件循環(huán)機(jī)制
單線程的同步等待極大影響效率,任務(wù)不得不一個(gè)一個(gè)等待執(zhí)行,對于網(wǎng)頁應(yīng)用是無法接受的。所以Javascript使用事件循環(huán)機(jī)制來解決異步任務(wù)的問題。本文就來講講Javascript的事件循環(huán)機(jī)制,希望對你有所幫助2022-09-09JavaScript實(shí)現(xiàn)點(diǎn)擊按鈕直接打印
很多網(wǎng)站都有此功能,當(dāng)瀏覽到底部時(shí)都會有一個(gè)打印按鈕,點(diǎn)擊打印按鈕就可以完成打印功能,功能非常不錯(cuò),人性化,下面通過本文給大家介紹JavaScript實(shí)現(xiàn)點(diǎn)擊按鈕就打印的代碼,需要的朋友參考下2016-01-01微信小程序 高德地圖路線規(guī)劃實(shí)現(xiàn)過程詳解
這篇文章主要介紹了微信小程序 路線規(guī)劃實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08javascript 讀取XML數(shù)據(jù),在頁面中展現(xiàn)、編輯、保存的實(shí)現(xiàn)
最近需要做這樣一個(gè)需求,數(shù)據(jù)保存在XML里,在頁面上通過表格顯示其內(nèi)容,可以修改內(nèi)容,再保存到XML。下面把做這個(gè)東西的過程記錄下來,做個(gè)筆記,也給需要的人一些幫助。2009-10-10js設(shè)置隨機(jī)切換背景圖片的簡單實(shí)例
下面小編就為大家?guī)硪黄猨s設(shè)置隨機(jī)切換背景圖片的簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11