0

0

javascript map对象是什么_和普通对象有何不同【教程】

紅蓮之龍

紅蓮之龍

发布时间:2026-01-20 21:39:59

|

401人浏览过

|

来源于php中文网

原创

map 与普通对象是本质不同的数据结构:键支持任意类型、无原型链、有确定插入顺序、提供 size/clear/has 等原生方法;而普通对象键仅限字符串/symbol、存在类型强制转换、遍历顺序不完全可靠、操作更繁琐。

javascript map对象是什么_和普通对象有何不同【教程】

Map 对象不是“带下划线的普通对象”,它和 {} 是完全不同的数据结构,不能用点号访问、没有原型链继承、键可以是任意类型——这些差异直接影响你能不能正确存取数据。

Map 的键可以是任意值,而普通对象只能是字符串或 Symbol

普通对象的键会被强制转为字符串(比如 {[1,2]: 'a'} 实际上是 {'1,2': 'a'}),Map 则保留原始类型:

  • new Map().set({}, 'value') —— 用空对象作键,合法且可查
  • new Map().set(NaN, 'nan') —— NaN 作为键能被正确识别(普通对象里 obj[NaN] = 'x' 等价于 obj['NaN'] = 'x'
  • obj[123]obj['123'] 指向同一个属性;map.get(123)map.get('123') 是两个独立键

Map 有确定的插入顺序,普通对象在 ES2015 后才部分保证

遍历 Map 时,keys()values()entries() 都严格按插入顺序返回;普通对象的属性顺序虽然现在大多遵循插入顺序,但仍有例外:

  • 数字键(如 '1''10')会被提前排序,{'10':1,'1':2} 遍历时先输出 '1''10'
  • Symbol 键总在最后,字符串键在前,但具体行为依赖引擎实现
  • Map 不受这些干扰,map.set('a',1).set(2,3).set(Symbol(),4) 就按这个顺序迭代

Map 的 size、遍历、清空操作更直接,普通对象要手动处理

普通对象没有原生 size 属性,也不能直接 clear(),常用写法容易出错:

MindShow
MindShow

MindShow官网 | AI生成PPT,快速演示你的想法

下载

立即学习Java免费学习笔记(深入)”;

const obj = { a: 1, b: 2 };
console.log(Object.keys(obj).length); // ✅ 得到 2,但要遍历一次
obj = {}; // ❌ 重赋值不改变原引用,其他地方仍持有旧对象
Object.keys(obj).forEach(k => delete obj[k]); // ✅ 但性能差、不可靠(可能跳过不可枚举属性)

const map = new Map();
map.set('a', 1).set('b', 2);
console.log(map.size); // ✅ 直接读取,O(1)
map.clear(); // ✅ 原地清空,无引用残留
  • map.has(key)key in objobj.hasOwnProperty(key) 更准确(不涉及原型链)
  • for (const [k, v] of map) 可直接解构,for...in 遍历对象会包含继承属性
  • 没有 map.toJSON(),要转 JSON 得手动 Array.from(map)[...map]

Map 不是语法糖,不能替代对象做配置或 DOM 属性映射

如果你只是存字符串键、不需要弱引用、也不关心键类型,用 {} 更轻量、可读性更好。Map 的开销明显更高:

  • 每个 Map 实例都带额外内存结构,初始化比空对象慢约 3–5 倍
  • V8 中 Map 查找复杂度平均 O(1),但常数项比对象高;小数据量(
  • 不能用点号或方括号语法直接访问:map.keymap['key'] 总是 undefined,必须用 map.get(key)
  • JSON 序列化不支持 Map,JSON.stringify(new Map([['a',1]])) 得到 '{}'

真正该用 Map 的场景很明确:需要非字符串键、依赖插入顺序、频繁增删且关注性能一致性。其余时候,别为了“新”而换——尤其当团队成员还在用 for...in 遍历对象时,Map 的 for...of 会悄悄漏掉逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1564

2023.10.24

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.9万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号