溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ES6新數(shù)據(jù)結(jié)構(gòu)Map功能怎么用

發(fā)布時(shí)間:2021-07-09 11:34:39 來(lái)源:億速云 閱讀:163 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹ES6新數(shù)據(jù)結(jié)構(gòu)Map功能怎么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

具體如下:

新數(shù)據(jù)結(jié)構(gòu)Map

JavaScript中對(duì)象的本質(zhì)是鍵值對(duì)的集合,但是鍵只能是字符串。為了彌補(bǔ)這種缺憾,ES6帶來(lái)了一種新的數(shù)據(jù)結(jié)構(gòu)Map。Map也是鍵值對(duì)的集合,只是鍵不僅可以是字符串還可以是其他數(shù)據(jù)類(lèi)型,比如:對(duì)象(是不是很神奇)。請(qǐng)看下面例子。

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

對(duì)于Map的操作有以下幾個(gè):

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

直接為Map賦初值的方法:

var m = new Map([[li_1,'hello'],[li_2,'world']]);

接受的參數(shù)為一個(gè)數(shù)組,數(shù)組內(nèi)的成員是表示一個(gè)一個(gè)鍵值對(duì)的數(shù)組。如果你蒙了,請(qǐng)看上行代碼的實(shí)際執(zhí)行情況:

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

如果對(duì)一個(gè)鍵多次賦值,后面的值會(huì)覆蓋前面的值。值得注意的是,當(dāng)鍵是對(duì)象時(shí),必須是引用相同,才認(rèn)為鍵是相同的。下面介紹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的第二個(gè)參數(shù)用于改變匿名函數(shù)中this指向

Map與其他數(shù)據(jù)類(lèi)型的轉(zhuǎn)換

Map轉(zhuǎn)數(shù)據(jù)的最簡(jiǎn)單方式是使用 ... 擴(kuò)展運(yùn)算符。例如:

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

Map轉(zhuǎn)對(duì)象時(shí),必須所有鍵都是字符串,使用Object.create()函數(shù)。Map轉(zhuǎn)JSON時(shí),要求也要求所有鍵都是字符串,使用JSON.Stringify()函數(shù)。

以上是“ES6新數(shù)據(jù)結(jié)構(gòu)Map功能怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI