1. 程式人生 > >ES6-新資料結構Map

ES6-新資料結構Map

新資料結構Map

JavaScript中物件的本質是鍵值對的集合,但是鍵只能是字串。為了彌補這種缺憾,ES6帶來了一種新的資料結構Map。Map也是鍵值對的集合,只是鍵不僅可以是字串還可以是其他資料型別,比如:物件(是不是很神奇)。請看下面例子。

var m = new Map();
var ul = document.getElementsByTagName('ul');
m.set(ul,'hi');
console.log(m.get(ul)); //hi

對於Map的操作有以下幾個:

m.set(ul,'content'); //為Map增加成員
m.get(ul);//獲取鍵 ul對應的值
m.has(ul);//返回布林值,判斷是否含有鍵 ul
m.delete(ul);//刪除鍵 ul,成功返回true,失敗返回false
m.size  //返回m長度
m.clear(); //清除m所有成員

直接為Map賦初值的方法:
<span style="font-size:14px;">var m = new Map([[li_1,'hello'],[li_2,'world']]);</span>
接受的引數為一個數組,陣列內的成員是表示一個一個鍵值對的陣列。如果你蒙了,請看上行程式碼的實際執行情況:
var li_1 = document.getElementsByTagName('li')[0];
var li_2 = document.getElementsByTagName('li')[1];
var list = [ [li_1,'hello'] , [li_2,'world'] ];
var m = new Map();
list.forEach( ([key,value]) => m.set(key,value) );
console.log(m.get(li_1)); //hello

如果對一個鍵多次賦值,後面的值會覆蓋前面的值。值得注意的是,當鍵是物件時,必須是引用相同,才認為鍵是相同的。下面介紹Map的遍歷方法。

var ul = document.getElementsByTagName('ul');
var li_1 = document.getElementsByTagName('li')[0];
var li_2 = document.getElementsByTagName('li')[1];
var list = [ [li_1,'hello'] , [li_2,'world'] ];
var m = new Map();
list.forEach( ([key,value]) => m.set(key,value) );
for ( let key of m.keys() ){
	console.log(key);
}
for ( let val of m.values() ){
	console.log(val);
}
for ( let item of m.entries() ){
	console.log(item[0],item[1]);
}
for ( let [key,val] of m.entries() ){
	console.log(key,val);
} 
m.forEach( function( val , key , ul ){
	console.log( this ); //ul
	console.log( val , key);
} , ul ); // forEach的第二個引數用於改變匿名函式中this指向

Map與其他資料型別的轉換

Map轉資料的最簡單方式是使用 ... 擴充套件運算子。例如:

console.log( ...m ); //[li, "hello"] [li, "world"]

Map轉物件時,必須所有鍵都是字串,使用Object.create()函式。Map轉JSON時,要求也要求所有鍵都是字串,使用JSON.Stringify()函式。