ES6新數(shù)據(jù)結構Map功能與用法示例
本文實例講述了ES6新數(shù)據(jù)結構Map功能與用法。分享給大家供大家參考,具體如下:
新數(shù)據(jù)結構Map
JavaScript中對象的本質是鍵值對的集合,但是鍵只能是字符串。為了彌補這種缺憾,ES6帶來了一種新的數(shù)據(jù)結構Map。Map也是鍵值對的集合,只是鍵不僅可以是字符串還可以是其他數(shù)據(jù)類型,比如:對象(是不是很神奇)。請看下面例子。
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']]);
接受的參數(shù)為一個數(shù)組,數(shù)組內的成員是表示一個一個鍵值對的數(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
如果對一個鍵多次賦值,后面的值會覆蓋前面的值。值得注意的是,當鍵是對象時,必須是引用相同,才認為鍵是相同的。下面介紹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的第二個參數(shù)用于改變匿名函數(shù)中this指向
Map與其他數(shù)據(jù)類型的轉換
Map轉數(shù)據(jù)的最簡單方式是使用 ... 擴展運算符。例如:
console.log( ...m ); //[li, "hello"] [li, "world"]
Map轉對象時,必須所有鍵都是字符串,使用Object.create()函數(shù)。Map轉JSON時,要求也要求所有鍵都是字符串,使用JSON.Stringify()函數(shù)。
希望本文所述對大家ECMAScript程序設計有所幫助。
相關文章
JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等屬性學
這篇文章主要介紹了JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等屬性學習筆記,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07詳解Python中l(wèi)ogging日志模塊在多進程環(huán)境下的使用
許多應用程序中都會有日志模塊,用于記錄系統(tǒng)在運行過程中的一些關鍵信息,以便于對系統(tǒng)的運行狀況進行跟蹤。這篇文章給大家主要介紹了在Python中l(wèi)ogging日志模塊在多進程環(huán)境下的使用,需要的朋友可以參考借鑒,下面來一起看看吧。2016-12-12Gulp實現(xiàn)靜態(tài)網(wǎng)頁模塊化的方法詳解
眾所周知Gulp.js 是一個自動化構建工具,開發(fā)者可以使用它在項目開發(fā)過程中自動執(zhí)行常見任務。下面這篇文章主要給大家介紹了關于Gulp實現(xiàn)靜態(tài)網(wǎng)頁模塊化的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。2018-01-01