91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES6新數據結構Map功能如何使用

發布時間:2022-04-20 16:14:31 來源:億速云 閱讀:152 作者:iii 欄目:大數據

這篇“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賦初值的方法:

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

接受的參數為一個數組,數組內的成員是表示一個一個鍵值對的數組。如果你蒙了,請看上行代碼的實際執行情況:

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()函數。

以上就是關于“ES6新數據結構Map功能如何使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

偏关县| 明星| 三都| 横山县| 石门县| 夏津县| 沙田区| 焉耆| 尼玛县| 浮梁县| 绥德县| 汶川县| 大安市| 南江县| 公主岭市| 长春市| 桓台县| 马鞍山市| 河曲县| 涞水县| 珲春市| 电白县| 隆回县| 辛集市| 汪清县| 武隆县| 青州市| 长兴县| 夹江县| 满城县| 禄丰县| 宜章县| 和静县| 隆昌县| 清水县| 宁阳县| 朝阳县| 西林县| 卢湾区| 昌邑市| 沙田区|