电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

何時(shí)使用Map來代替普通的JS對(duì)象

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

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

幸運(yù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作為鍵,沒有問題。相反,布爾鍵在普通對(duì)象中不起作用。

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

對(duì)象作為鍵

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

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

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

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

這種方法最大的問題是按鍵訪問值的復(fù)雜度O(n),咱們必須遍歷整個(gè)數(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的一個(gè)專門版本)不需要這么麻煩就能做到上面的事情:它只接受對(duì)象作為鍵。

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

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

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只接受對(duì)象作為鍵,并少了一些方法。

2. map 對(duì)鍵名沒有限制

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

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

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

在對(duì)象參與者上定義的屬性toString覆蓋從原型繼承的toString()方法。這中斷了isObject(),因?yàn)樗蕾囉趖oString()方法。

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

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

何時(shí)使用Map來代替普通的JS對(duì)象

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

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

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

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

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

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有一個(gè)名為toString的屬性,toString()方法都可以正常工作。

3. map 是可迭代

為了遍歷普通對(duì)象的屬性,必須使用其他的輔助靜態(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)返回從對(duì)象提取的鍵值對(duì)數(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),展開運(yùn)算符[...map]。

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

4. map 的大小

普通對(duì)象的另一個(gè)問題是,您無法立馬知道它包含的屬性的數(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ù)量更加簡(jiǎn)單:examsMap.size。

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

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 东莞猎头公司_深圳猎头公司_广州猎头公司-广东万诚猎头提供企业中高端人才招聘服务 | 杭州画室_十大画室_白墙画室_杭州美术培训_国美附中培训_附中考前培训_升学率高的画室_美术中考集训美术高考集训基地 | 升降机-高空作业车租赁-蜘蛛车-曲臂式伸缩臂剪叉式液压升降平台-脚手架-【普雷斯特公司厂家】 | 液压油缸-液压站生产厂家-洛阳泰诺液压科技有限公司 | 临沂招聘网_人才市场_招聘信息_求职招聘找工作请认准【马头商标】 | 湿地保护| 闭端端子|弹簧螺式接线头|防水接线头|插线式接线头|端子台|电源线扣+护线套|印刷电路板型端子台|金笔电子代理商-上海拓胜电气有限公司 | 移动机器人产业联盟官网 | 服务器之家 - 专注于服务器技术及软件下载分享 | 并网柜,汇流箱,电控设备,中高低压开关柜,电气电力成套设备,PLC控制设备订制厂家,江苏昌伟业新能源科技有限公司 | 法兰连接型电磁流量计-蒸汽孔板节流装置流量计-北京凯安达仪器仪表有限公司 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 立式矫直机_卧式矫直机-无锡金矫机械制造有限公司 | 螺杆式冷水机-低温冷水机厂家-冷冻机-风冷式-水冷式冷水机-上海祝松机械有限公司 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 「银杏树」银杏树行情价格_银杏树种植_山东程锦园林 | 智慧养老_居家养老_社区养老_杰佳通| 数显恒温培养摇床-卧式/台式恒温培养摇床|朗越仪器 | 焦作网 WWW.JZRB.COM | 科研ELISA试剂盒,酶联免疫检测试剂盒,昆虫_植物ELISA酶免试剂盒-上海仁捷生物科技有限公司 | 冷藏车-东风吸污车-纯电动环卫车-污水净化车-应急特勤保障车-程力专汽厂家-程力专用汽车股份有限公司销售二十一分公司 | 艾默生变频器,艾默生ct,变频器,ct驱动器,广州艾默生变频器,供水专用变频器,风机变频器,电梯变频器,艾默生变频器代理-广州市盟雄贸易有限公司官方网站-艾默生变频器应用解决方案服务商 | 博莱特空压机|博莱特-阿特拉斯独资空压机品牌核心代理商 | 专业广州网站建设,微信小程序开发,一物一码和NFC应用开发、物联网、外贸商城、定制系统和APP开发【致茂网络】 | 陶氏道康宁消泡剂_瓦克消泡剂_蓝星_海明斯德谦_广百进口消泡剂 | 山东彩钢板房,山东彩钢活动房,临沂彩钢房-临沂市贵通钢结构工程有限公司 | 称重传感器,测力传感器,拉压力传感器,压力变送器,扭矩传感器,南京凯基特电气有限公司 | 伶俐嫂培训学校_月嫂培训班在哪里报名学费是多少_月嫂免费政府培训中心推荐 | 电销卡_稳定企业大语音卡-归属地可选-世纪通信 | 重庆私家花园设计-别墅花园-庭院-景观设计-重庆彩木园林建设有限公司 | 购买舔盐、舔砖、矿物质盐压块机,鱼饵、鱼饲料压块机--请到杜甫机械 | DAIKIN电磁阀-意大利ATOS电磁阀-上海乾拓贸易有限公司 | 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂_帽子厂_浙江高普制帽厂 | 冷柜风机-冰柜电机-罩极电机-外转子风机-EC直流电机厂家-杭州金久电器有限公司 | 洗地机_全自动洗地机_手推式洗地机【上海滢皓环保】 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 工业雾炮机_超细雾炮_远程抑尘射雾器-世纪润德环保设备 | 泰兴市热钻机械有限公司-热熔钻孔机-数控热熔钻-热熔钻孔攻牙一体机 | 儋州在线-儋州招聘找工作、找房子、找对象,儋州综合生活信息门户! | 中央空调维修、中央空调保养、螺杆压缩机维修-苏州东菱空调 |