欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ES6新數(shù)據(jù)結(jié)構(gòu)Map功能與用法示例

 更新時間:2017年03月31日 09:56:23   作者:柒青衿  
這篇文章主要介紹了ES6新數(shù)據(jù)結(jié)構(gòu)Map功能與用法,結(jié)合實例形式分析了Map的功能、使用方法及相關(guān)注意事項,需要的朋友可以參考下

本文實例講述了ES6新數(shù)據(jù)結(jié)構(gòu)Map功能與用法。分享給大家供大家參考,具體如下:

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

JavaScript中對象的本質(zhì)是鍵值對的集合,但是鍵只能是字符串。為了彌補這種缺憾,ES6帶來了一種新的數(shù)據(jù)結(jié)構(gòu)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對應(yīng)的值
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ù)組內(nèi)的成員是表示一個一個鍵值對的數(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

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

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

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

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

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

希望本文所述對大家ECMAScript程序設(shè)計有所幫助。

相關(guān)文章

  • 微信小程序?qū)崿F(xiàn)自定義動畫彈框/提示框的方法實例

    微信小程序?qū)崿F(xiàn)自定義動畫彈框/提示框的方法實例

    這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)自定義動畫彈框/提示框的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等屬性學(xué)習(xí)筆記

    JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等屬性學(xué)

    這篇文章主要介紹了JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等屬性學(xué)習(xí)筆記,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 小程序?qū)崿F(xiàn)列表刪除功能

    小程序?qū)崿F(xiàn)列表刪除功能

    這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)列表刪除功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • 微信小程序框架wepy之動態(tài)控制類名

    微信小程序框架wepy之動態(tài)控制類名

    這篇文章主要為大家詳細(xì)介紹了微信小程序框架wepy之動態(tài)控制類名,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • webpack2.0配置postcss-loader的方法

    webpack2.0配置postcss-loader的方法

    本篇文章主要介紹了webpack2.0配置postcss-loader的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • 純文字版返回頂端的js代碼

    純文字版返回頂端的js代碼

    這篇文章介紹了純文字版返回頂端的js代碼,有需要的朋友可以參考一下
    2013-08-08
  • 詳解Python中l(wèi)ogging日志模塊在多進程環(huán)境下的使用

    詳解Python中l(wèi)ogging日志模塊在多進程環(huán)境下的使用

    許多應(yīng)用程序中都會有日志模塊,用于記錄系統(tǒng)在運行過程中的一些關(guān)鍵信息,以便于對系統(tǒng)的運行狀況進行跟蹤。這篇文章給大家主要介紹了在Python中l(wèi)ogging日志模塊在多進程環(huán)境下的使用,需要的朋友可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • JavaScript檢測用戶是否在線的6種方法總結(jié)

    JavaScript檢測用戶是否在線的6種方法總結(jié)

    這篇文章主要為大家詳細(xì)介紹了JavaScript中實現(xiàn)檢測用戶是否在線的6種常用方法,文中的示例代碼講解詳細(xì),感興趣的可以跟隨小編一起學(xué)習(xí)一下
    2023-08-08
  • Gulp實現(xiàn)靜態(tài)網(wǎng)頁模塊化的方法詳解

    Gulp實現(xiàn)靜態(tài)網(wǎng)頁模塊化的方法詳解

    眾所周知Gulp.js 是一個自動化構(gòu)建工具,開發(fā)者可以使用它在項目開發(fā)過程中自動執(zhí)行常見任務(wù)。下面這篇文章主要給大家介紹了關(guān)于Gulp實現(xiàn)靜態(tài)網(wǎng)頁模塊化的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。
    2018-01-01
  • js中設(shè)計一段程序,讓它能夠打印自己的方法收集藏

    js中設(shè)計一段程序,讓它能夠打印自己的方法收集藏

    js中設(shè)計一段程序,讓它能夠打印自己的方法收集藏...
    2007-03-03

最新評論