ES6新資料結構Map功能與用法樣本,es6map

來源:互聯網
上載者:User

ES6新資料結構Map功能與用法樣本,es6map

本文執行個體講述了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);//返回布爾值,判斷是否含有鍵 ulm.delete(ul);//刪除鍵 ul,成功返回true,失敗返回falsem.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()函數。

希望本文所述對大家ECMAscript程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.