ES6中Set和Map數(shù)據(jù)結(jié)構(gòu)的簡單講解
Set
ES6 提供了新的數(shù)據(jù)結(jié)構(gòu) Set。它類似于數(shù)組,但是成員的值都是唯一的,沒有重復(fù)的值。 Set本身是一個構(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 加入值的時候,不會發(fā)生類型轉(zhuǎn)換,所以5和"5"是兩個不同的值。Set 內(nèi)部判斷兩個值是否不同,使用的算法叫做“Same-value-zero equality”,它類似于精確相等運算符(===),主要的區(qū)別是向 Set 加入值時認為NaN等于自身,而精確相等運算符認為NaN不等于自身。
Set 實例的屬性和方法 Set 結(jié)構(gòu)的實例有以下屬性。
Set.prototype.constructor:構(gòu)造函數(shù),默認就是Set函數(shù)。
Set.prototype.size:返回Set實例的成員總數(shù)。
Set 實例的方法分為兩大類:操作方法(用于操作數(shù)據(jù))和遍歷方法(用于遍歷成員)。下面先介紹四個操作方法。
Set.prototype.add(value):添加某個值,返回 Set 結(jié)構(gòu)本身。
Set.prototype.delete(value):刪除某個值,返回一個布爾值,表示刪除是否成功。
Set.prototype.has(value):返回一個布爾值,表示該值是否為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)的實例有四個遍歷方法,可以用于遍歷成員。
Set.prototype.keys():返回鍵名的遍歷器
Set.prototype.values():返回鍵值的遍歷器
Set.prototype.entries():返回鍵值對的遍歷器
Set.prototype.forEach():使用回調(diào)函數(shù)遍歷每個成員
需要特別指出的是,Set的遍歷順序就是插入順序。這個特性有時非常有用,比如使用 Set 保存一個回調(diào)函數(shù)列表,調(diào)用時就能保證按照添加順序調(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ù)組去重后的實現(xiàn)映射數(shù)組
set實例本身沒有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)上只能用字符串當作鍵。這給它的使用帶來了很大的限制。
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)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS腳本實現(xiàn)動態(tài)給標簽控件添加事件的方法
這篇文章主要介紹了JS腳本實現(xiàn)動態(tài)給標簽控件添加事件的方法,結(jié)合實例形式分析了javascript添加事件監(jiān)聽的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2016-06-06微信小程序 高德地圖路線規(guī)劃實現(xiàn)過程詳解
這篇文章主要介紹了微信小程序 路線規(guī)劃實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08javascript 讀取XML數(shù)據(jù),在頁面中展現(xiàn)、編輯、保存的實現(xiàn)
最近需要做這樣一個需求,數(shù)據(jù)保存在XML里,在頁面上通過表格顯示其內(nèi)容,可以修改內(nèi)容,再保存到XML。下面把做這個東西的過程記錄下來,做個筆記,也給需要的人一些幫助。2009-10-10