0

0

javascript如何遍历对象和数组_有哪些方法【教程】

狼影

狼影

发布时间:2026-01-31 15:20:01

|

710人浏览过

|

来源于php中文网

原创

JavaScript遍历应按数据结构选择:对象用Object.keys()/values()/entries()避免原型污染,数组优先for...of;for...in仅适用于对象且需hasOwnProperty过滤,禁用于数组。

javascript如何遍历对象和数组_有哪些方法【教程】

JavaScript 中遍历对象和数组的方法很多,但不是所有都适合你的场景——关键看你要不要处理原型链、是否需要兼容旧环境、是否要跳过不可枚举属性,或者是否在写函数式风格代码。

for...in 会遍历对象的可枚举属性(包括继承的)

它常被误用于数组,但实际是为对象设计的。问题在于:for...in 会遍历原型链上的可枚举属性,且不保证顺序(尤其在数字键混杂时)。

  • 遍历对象时,用 Object.prototype.hasOwnProperty.call(obj, key) 过滤掉继承属性
  • 绝对不要用 for...in 遍历数组——它会把数组方法(如 pushmap)也当作键遍历,如果原型被污染就更危险
  • ES6 后更推荐用 Object.keys() + for...offorEach

Object.keys() / Object.values() / Object.entries() 是安全遍历对象的起点

这三个方法只返回对象**自身**的可枚举属性,不触碰原型链,返回值都是数组,因此能直接使用数组方法。

  • Object.keys(obj) 返回字符串键名数组,适合需要操作 key 的场景
  • Object.values(obj) 返回值数组,注意:值的顺序与 Object.keys() 严格对应(ES2017+)
  • Object.entries(obj) 返回 [key, value] 二元数组,配合解构最简洁:for (const [k, v] of Object.entries(obj)) { ... }
  • 它们都不处理 symbol 键;要包含 symbol,得用 Reflect.ownKeys()

数组遍历优先选 for...of,而不是 for...in 或传统 for 循环

for...of 直接消费迭代器,语义清晰、无索引管理负担,且天然支持 break/continue,比 forEach 更灵活。

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

下载

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

  • for (const item of arr) { ... } —— 最简写法,适用于只需值的场景
  • for (const [i, item] of arr.entries()) { ... } —— 需要索引时的推荐写法,比手动维护 i++ 安全
  • arr.forEach((item, i) => { ... }) —— 不能用 break,且无法用 await(异步回调需改用 for...of
  • 传统 for (let i = 0; i 在性能敏感循环中仍有价值,但多数业务代码没必要

Map 和 Set 的遍历比普通对象更直观

如果你本就可以控制数据结构,优先用 Map 替代对象存键值对,用 Set 替代去重数组——它们的遍历接口统一、语义明确、不污染原型。

  • map.forEach((value, key) => { ... })for (const [key, value] of map) 效果一致
  • set.forEach(value => { ... })for (const value of set),没有歧义
  • 注意:Map 的键可以是任意类型(包括对象、函数),而对象只能用字符串或 symbol 作键
  • 从对象转 Mapnew Map(Object.entries(obj));反过来:Object.fromEntries(map)

最容易被忽略的是:遍历前先想清楚「这个数据结构是谁创建的?有没有可能被代理/扩展/污染?」——比如后端返回的对象若带 __proto__ 字段,在低版本浏览器里可能意外触发原型污染。这时候用 Object.entries()for...in 多一层保障,而用 Map 则彻底绕开这个问题。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
es6新特性
es6新特性

es6新特性有:1、块级作用域变量;2、箭头函数;3、模板字符串;4、解构赋值;5、默认参数;6、 扩展运算符;7、 类和继承;8、Promise。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.07.17

es6新特性有哪些
es6新特性有哪些

es6的新特性有:1、块级作用域;2、箭头函数;3、解构赋值;4、默认参数;5、扩展运算符;6、模板字符串;7、类和模块;8、迭代器和生成器;9、Promise对象;10、模块化导入和导出等等。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

2025.12.24

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

76

2025.12.04

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

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

531

2023.09.20

java中break的作用
java中break的作用

本专题整合了java中break的用法教程,阅读专题下面的文章了解更多详细内容。

119

2025.10.15

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

258

2025.10.24

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

258

2025.10.24

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

33

2026.01.31

热门下载

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

精品课程

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

共58课时 | 4.4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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