這篇文章主要介紹“ES6新數(shù)據(jù)結(jié)構(gòu)Map功能如何用”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“ES6新數(shù)據(jù)結(jié)構(gòu)Map功能如何用”文章能幫助大家解決問題。
成都創(chuàng)新互聯(lián)專注于企業(yè)全網(wǎng)整合營銷推廣、網(wǎng)站重做改版、渝北網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5技術(shù)、商城網(wǎng)站制作、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為渝北等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
新數(shù)據(jù)結(jié)構(gòu)Map
JavaScript中對象的本質(zhì)是鍵值對的集合,但是鍵只能是字符串。為了彌補(bǔ)這種缺憾,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的操作有以下幾個(gè):
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ù)為一個(gè)數(shù)組,數(shù)組內(nèi)的成員是表示一個(gè)一個(gè)鍵值對的數(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
如果對一個(gè)鍵多次賦值,后面的值會(huì)覆蓋前面的值。值得注意的是,當(dāng)鍵是對象時(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ù)類型的轉(zhuǎn)換
Map轉(zhuǎn)數(shù)據(jù)的最簡單方式是使用 ... 擴(kuò)展運(yùn)算符。例如:
console.log( ...m ); //[li, "hello"] [li, "world"]
Map轉(zhuǎn)對象時(shí),必須所有鍵都是字符串,使用Object.create()函數(shù)。Map轉(zhuǎn)JSON時(shí),要求也要求所有鍵都是字符串,使用JSON.Stringify()函數(shù)。
關(guān)于“ES6新數(shù)據(jù)結(jié)構(gòu)Map功能如何用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。
網(wǎng)頁標(biāo)題:ES6新數(shù)據(jù)結(jié)構(gòu)Map功能如何用
文章網(wǎng)址:http://sd-ha.com/article30/iheiso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、品牌網(wǎng)站制作、網(wǎng)站導(dǎo)航、小程序開發(fā)、企業(yè)建站、定制網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)