日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

何時使用Map來代替普通的JS對象

瀏覽:187日期:2024-03-30 10:40:55
1. Map 接受任何類型的鍵

如前所述,如果對象的鍵不是string或symbol,JS 將隱式地將其轉(zhuǎn)換為字符串。

幸運的是,map的鍵類型沒有問題

const numbersMap = new Map();numbersMap.set(1, ’one’);numbersMap.set(2, ’two’);[...numbersMap.keys()]; // => [1, 2]

1和2是numbersMap中的鍵,這些鍵的類型(數(shù)字)保持不變。

可以在mpa中使用任何鍵類型:數(shù)字、布爾值、字符串和symbol。

const booleansMap = new Map();booleansMap.set(true, 'Yep');booleansMap.set(false, 'Nope');[...booleansMap.keys()]; // => [true, false]

booleansMap使用booleans作為鍵,沒有問題。相反,布爾鍵在普通對象中不起作用。

來突破一下想象:是否將整個對象作為map的鍵,答案:可以的。

對象作為鍵

假設你需要存儲一些與對象相關(guān)的數(shù)據(jù),而不需要將這些數(shù)據(jù)附加到對象本身。使用普通對象是不可能的。

解決方法是使用對象-值元組數(shù)組:

const foo = { name: ’foo’ };const bar = { name: ’bar’ };const kindOfMap = [ [foo, ’Foo related data’], [bar, ’Bar related data’]]

kindOfMap是一個數(shù)組,包含對象和關(guān)聯(lián)值的對。

這種方法最大的問題是按鍵訪問值的復雜度O(n),咱們必須遍歷整個數(shù)組才能通過鍵獲得所需的值。

function getByKey(kindOfMap, key) { for (const [k, v] of kindOfMap) { if (key === k) { return v; } } return undefined;}getByKey(kindOfMap, foo); // => ’Foo related data’

WeakMap(Map的一個專門版本)不需要這么麻煩就能做到上面的事情:它只接受對象作為鍵。

Map和Weakmap之間的主要區(qū)別是,Weakmap允許對鍵對象進行垃圾收集,從而防止內(nèi)存泄漏。

好了,用WeakMap重構(gòu)上面的代碼就變得很簡單了:

const foo = { name: ’foo’ };const bar = { name: ’bar’ };const mapOfObjects = new WeakMap();mapOfObjects.set(foo, ’Foo related data’);mapOfObjects.set(bar, ’Bar related data’);mapOfObjects.get(foo); // => ’Foo related data’

與Map相反,WeakMap只接受對象作為鍵,并少了一些方法。

2. map 對鍵名沒有限制

JS 中的任何對象都從原型對象繼承屬性,普通對象也是如此。

如果重寫從原型繼承的屬性,則可能會破壞依賴這些原型屬性的代碼:

function isPlainObject(value) { return value.toString() === ’[object Object]’;}const actor = { name: ’Harrison Ford’, toString: ’Actor: Harrison Ford’};// Does not work!isPlainObject(actor); // TypeError: value.toString is not a function

在對象參與者上定義的屬性toString覆蓋從原型繼承的toString()方法。這中斷了isObject(),因為它依賴于toString()方法。

檢查普通對象從原型繼承的屬性和方法的列表, 避免使用這些方法名定義自定義屬性。

例如,假設有一個管理某些自定義字段的用戶界面。 用戶可以通過指定名稱和值來添加自定義字段:

何時使用Map來代替普通的JS對象

將定制字段的狀態(tài)存儲到普通對象中會很方便:

const userCustomFields = { ’color’: ’blue’, ’size’: ’medium’, ’toString’: ’A blue box’};

但是用戶可能會選擇一個自定義字段名稱,例如toString(如示例中所示),構(gòu)造函數(shù)等,這可能會破壞咱們的對象。

不要使用用戶輸入的值作為普通對象上鍵。

map沒有這個問題,鍵值名稱不受限制:

function isMap(value) { return value.toString() === ’[object Map]’;}const actorMap = new Map();actorMap.set(’name’, ’Harrison Ford’);actorMap.set(’toString’, ’Actor: Harrison Ford’);// Works!isMap(actorMap); // => true

不管actorMap有一個名為toString的屬性,toString()方法都可以正常工作。

3. map 是可迭代

為了遍歷普通對象的屬性,必須使用其他的輔助靜態(tài)函數(shù),如Object.keys()或Object.entries():

const colorsHex = { ’white’: ’#FFFFFF’, ’black’: ’#000000’};for (const [color, hex] of Object.entries(colorsHex)) { console.log(color, hex);}// ’white’ ’#FFFFFF’// ’black’ ’#000000’

Object.entries(colorsHex)返回從對象提取的鍵值對數(shù)組。

但是,map本身是可迭代的:

const colorsHexMap = new Map();colorsHexMap.set(’white’, ’#FFFFFF’);colorsHexMap.set(’black’, ’#000000’);for (const [color, hex] of colorsHexMap) { console.log(color, hex);}// ’white’ ’#FFFFFF’// ’black’ ’#000000’

colorsHexMap是可迭代。可以在任何接受迭代的地方使用它:for()循環(huán),展開運算符[...map]。

map提供了返回可迭代方法:map.keys()遍歷鍵,map.values()遍歷值

4. map 的大小

普通對象的另一個問題是,您無法立馬知道它包含的屬性的數(shù)量。

const exams = { ’John Smith’: ’10 points’, ’Jane Doe’: ’8 points’,};Object.keys(exams).length; // => 2

要確定exams的大小,必須通過所有鍵來確定它們的數(shù)量。

map 提供了 size 屬性,表示屬性的數(shù)量。

const examsMap = new Map([ [’John Smith’, ’10 points’], [’Jane Doe’, ’8 points’],]); examsMap.size; // => 2

確定map的屬性的數(shù)量更加簡單:examsMap.size。

以上就是何時使用Map來代替普通的JS對象的詳細內(nèi)容,更多關(guān)于JS對象的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲日本免费电影| 成人va天堂| 日韩在线a电影| 免费国产亚洲视频| 亚洲免费专区| 蜜桃视频在线观看一区二区| 自由日本语亚洲人高潮| 不卡在线一区二区| 1024精品久久久久久久久| 久久人人88| 国产毛片久久| 日本成人中文字幕| 欧美黑人巨大videos精品| 精品视频在线一区二区在线| 国产精品原创| 欧美亚洲国产激情| 久久国产精品久久w女人spa| 亚洲一二av| 国产精品毛片久久久| 精品亚洲精品| 99精品电影| 国产视频亚洲| 日韩1区2区日韩1区2区| 国产精品一国产精品| 精品九九在线| 亚洲一级黄色| 亚洲精品在线a| 国产精品美女久久久久久不卡| 国产91在线播放精品| 久久亚洲精品中文字幕蜜潮电影| 尹人成人综合网| 蜜桃av一区二区在线观看| 欧美日韩亚洲三区| av中文字幕在线观看第一页| 久久精品不卡| 只有精品亚洲| 国产精品v日韩精品v欧美精品网站| 捆绑调教美女网站视频一区| 特黄特色欧美大片| 亚洲主播在线| 国产精品入口久久| 日韩欧美字幕| 在线精品一区| 精品一区不卡| 欧美日韩四区| 欧美一区不卡| 欧美sm一区| 亚洲精品伊人| 精品国产欧美日韩| 国产亚洲综合精品| 久久中文字幕导航| 亚洲福利国产| 国产欧美啪啪| 999精品在线| 日韩高清不卡一区| 蜜桃av.网站在线观看| 亚洲影院天堂中文av色| 日本久久黄色| 日韩中出av| 亚洲a在线视频| 国产视频一区二区在线播放| 欧美亚洲国产精品久久| 国产探花一区在线观看| 蜜桃tv一区二区三区| 久久精品97| 亚洲欧洲一区二区天堂久久| 国产精品mm| 在线一区视频| 激情不卡一区二区三区视频在线| 天堂av在线一区| 国产伦久视频在线观看| 蜜桃视频在线观看一区二区| 中文字幕高清在线播放| 日韩精品中文字幕吗一区二区| 久久久9色精品国产一区二区三区| 国产欧美高清视频在线| 香蕉精品999视频一区二区| 精品日产乱码久久久久久仙踪林| 久久国产精品久久久久久电车| 麻豆网站免费在线观看| 欧美日韩一区二区三区在线电影| 国产精品99一区二区| 国产福利亚洲| 中文字幕一区二区精品区| 日韩中文视频| 久久不卡国产精品一区二区| 亚洲永久精品唐人导航网址| 今天的高清视频免费播放成人| 精品视频一区二区三区在线观看 | 国产日韩欧美三级| 五月精品视频| 国产精品亚洲一区二区三区在线观看| 欧美日韩黄网站| 蜜臀精品久久久久久蜜臀| 亚洲福利久久| 日韩国产综合| 福利精品在线| 美腿丝袜亚洲一区| 日本亚洲最大的色成网站www| 欧美日韩三区| 欧美aa在线观看| 精品国产三区在线| 欧美精品三级在线| 亚洲免费在线| 久久精品国产大片免费观看| 日韩国产一区二区| 国内自拍视频一区二区三区| 国产精品videosex极品| 日韩福利视频网| 亚洲毛片视频| 在线看片一区| 爽好多水快深点欧美视频| 不卡中文一二三区| 欧美日韩一区二区综合| 综合日韩av| 日韩电影二区| 中文字幕成在线观看| 国产美女高潮在线| 久久亚洲黄色| 久久精品资源| 久久精品二区亚洲w码| 精品久久久中文字幕| 国产91在线播放精品| 精品国产亚洲一区二区三区在线| 免费一区二区三区在线视频| 久久99久久久精品欧美| 国产精品久久久久久av公交车| 国产精品任我爽爆在线播放| 国产精品成人3p一区二区三区| 麻豆高清免费国产一区| 精品一区二区三区的国产在线观看| 国产一区2区| 国产精品亚洲一区二区三区在线观看| 色婷婷综合网| 久久精品免费一区二区三区 | 国产精品一区二区三区四区在线观看 | 欧美精品第一区| 91福利精品在线观看| 国产区精品区| 久久在线91| 日韩专区精品| 国精品一区二区| 国产视频一区免费看| 视频在线观看一区二区三区| 涩涩涩久久久成人精品| 欧美午夜三级| 精品精品国产三级a∨在线| 日本久久综合| 婷婷成人综合| 亚洲午夜免费| 国产精品videosex极品| 国产在线观看www| 伊人久久大香线蕉av不卡| 免费看的黄色欧美网站| 日韩欧美中文字幕一区二区三区| 国产精品香蕉| 日韩久久视频| 黄页网站一区| 国产欧美日韩一区二区三区四区| 成人精品视频| 日韩视频久久| 欧美日韩1区| 伊伊综合在线| 视频一区二区中文字幕| 国产精品毛片aⅴ一区二区三区| 成人三级高清视频在线看| 国产字幕视频一区二区| 六月丁香综合| 久久成人高清| 99久久久久国产精品| 日韩一区二区三区精品视频第3页| 久久久亚洲欧洲日产| 久久精品国产www456c0m| 一区二区精品| 欧美国产一级| 亚洲久久视频| 激情视频网站在线播放色| 国产精品美女久久久浪潮软件| 国产欧美激情| 免费观看不卡av| 国产日本精品| 五月综合激情| 久久精品超碰| 欧美日韩激情| 欧美aaaaaa午夜精品| 亚洲国产一区二区在线观看 | 精品美女久久| 国产视频亚洲| 国内自拍视频一区二区三区| 亚洲欧美日韩国产综合精品二区| 麻豆91精品91久久久的内涵| 99精品99| 精品国产午夜肉伦伦影院 | 青草综合视频| 久久久精品久久久久久96| 91精品国产自产观看在线| 蜜桃av在线播放| 国产情侣一区在线| 夜久久久久久| 日本少妇一区|