JavaScript 对象遍历的几种方式

JavaScript 对象遍历的几种方式JavaScript 对象遍历的几种方式

方式一:for…in…

// Object 原型链上扩展的方法也会被遍历出来 const obj = { name: 'zhangsan', age: 13,fun: ()=>{}}; for (const i in obj) { console.log(i, ':', obj[i]); } // name : zhangsan // age : 13 // fun : () => {} //如果只需要获取对象的实例属性,可以使用 hasOwnProperty 进行过滤 const obj = { name: 'zhangsan', age: 13,fun: ()=>{}}; for (const i in obj) { if (Object.prototype.hasOwnProperty.call(obj, i)) { console.log(i, ':', obj[i]); } } // name : zhangsan // age : 13

方式二:Object.keys

//用于获取对象自身所有的可枚举的属性值,但不包括原型中的属性,然后返回一个由属性名组成的数组。 const str = 'helloworld'; console.log(Object.keys(str)); // ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"] const arr = ['a', 'b', 'c']; console.log(Object.keys(arr)); // ["0", "1", "2"] const obj = { name: 'zhangsan', age: 13 }; console.log(Object.keys(obj)); // ["name", "age"]

方式三:Object.values

//用于获取对象自身所有的可枚举的属性值,但不包括原型中的属性,然后返回一个由属性值组成的数组。 const str = 'helloworld'; console.log(Object.values(str)); // ["h", "e", "l", "l", "o", "w", "o", "r", "l", "d"] const arr = ['a', 'b', 'c']; console.log(Object.values(arr)); // ["a", "b", "c"] const obj = { name: 'zhangsan', age: 13 }; console.log(Object.values(obj)); // ["zhangsan", 13]

方式四:Object.entries

//用于获取对象自身所有的可枚举的属性值,但不包括原型中的属性,然后返回二维数组。每一个子数组由对象的属性名、属性值组成。是一种可以同时拿到属性名与属性值的方法。 const str = 'hello'; for (const [key, value] of Object.entries(str)) { console.log(`${key}: ${value}`); } // 0: h // 1: e // 2: l // 3: l // 4: o const arr = ['a', 'b', 'c']; for (const [key, value] of Object.entries(arr)) { console.log(`${key}: ${value}`); } // 0: a // 1: b // 2: c const obj = { name: 'zhangsan', age: 13 }; for (const [key, value] of Object.entries(obj)) { console.log(`${key}: ${value}`); } // name: zhangsan // age: 13

方式五:Object.getOwnPropertyNames

//用于获取对象自身所有的可枚举的属性值(不包括 Symbol 值作为名称的属性),但不包括原型中的属性,然后返回一个由属性名组成的数组。 Object.prototype.fun = () => {}; Array.prototype.fun = () => {}; const str = 'hello' console.log(Object.getOwnPropertyNames(str)); // ["0", "1", "2", "3", "4", "length"] const arr = ['a', 'b', 'c']; console.log(Object.getOwnPropertyNames(arr)); // ["0", "1", "2", "length"] const obj = { name: 'zhangsan', age: 13 }; const symbol1 = Symbol('symbol1') const symbol2 = Symbol('symbol2') obj[symbol1] = 'hello' obj[symbol2] = 'world' console.log(Object.getOwnPropertyNames(obj)); // ["name", "age"]

方式六:Object.getOwnPropertySymbols()

//用于获取指定对象的所有 Symbol 属性名。该方法返回一个数组,成员是当前对象的所有用作属性名的 Symbol 值。 const obj = { name: 'zhangsan', age: 13 }; const symbol1 = Symbol('symbol1') const symbol2 = Symbol('symbol2') obj[symbol1] = 'hello' obj[symbol2] = 'world' console.log(Object.getOwnPropertySymbols(obj)); // [Symbol(symbol1), Symbol(symbol2)]

方式七:Reflect.ownKeys()

//返回一个数组,包含对象自身的所有属性,不管是属性名是 Symbol 或字符串,也不管是否可枚举 const obj = { name: 'zhangsan', age: 13 }; const symbol1 = Symbol('symbol1') const symbol2 = Symbol('symbol2') obj[symbol1] = 'hello' obj[symbol2] = 'world' console.log(Reflect.ownKeys(obj)); // ["name", "age", Symbol(symbol1), Symbol(symbol2)]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/178398.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午5:23
下一篇 2026年3月26日 下午5:24


相关推荐

  • java.lang.Math中的基本方法

    java.lang.Math中的基本方法java.lang.Math类提供的方法都是static的,“静态引入”使得不必每次在调用类方法时都在方法前写上类名:importstaticjava.lang.Math.*;这样在调用Math

    2022年7月2日
    28
  • python写的hadoop实战_Hadoop实战

    python写的hadoop实战_Hadoop实战Hadoop 实战 1Hadoop 简介 1 1 什么是 Hadoop1 1 1Hadoop 概述 1 1 2Hadoop 的历史 1 1 3Hadoop 的功能与作用 1 1 4Hadoop 的优势 1 1 5Hadoop 的应用现状和发展趋势 1 2Hadoop 项目及其结构 1 3Hadoop 的体系结构 1 3 1HDFS 的体系结构 1 3 2MapReduce 的体系结构 1 4Hadoop 与分布式开发 1 5

    2026年3月20日
    2
  • 整除的尾数_整除数

    整除的尾数_整除数整除的尾数时间限制:1000 ms | 内存限制:65535 KB难度:0描述一个整数,只知道前几位,不知道末二位,被另一个整数除尽了,那么该数的末二位该是什么呢?输入输入数据有若干组,每组数据包含二个整数a,b(0输出对应每组数据,将满足条件的所有尾数在一行内输出,格式见样本输出。同组数据的输出,其每个尾数之间空一格,行末没有空格。样例输入

    2025年5月24日
    3
  • yarn的安装及使用教程

    yarn的安装及使用教程一 引言之前出过一篇关于用 npm 创建 react 项目的介绍与使用教程 本文在此介绍并对比一下 yarn 的使用

    2026年3月20日
    3
  • “Python小屋”免费资源汇总(截至2018年11月28日)

    “Python小屋”免费资源汇总(截至2018年11月28日)为方便广大Python爱好者查阅和学习,特整理汇总微信公众号“Python小屋”开通29个月以来推送过的700多篇文章清单,如果需要本清单的电子版,可以在公众号后台发送消息“资源汇总”获取…

    2026年4月16日
    4
  • 第一章 JAX-WS认识

    第一章 JAX-WS认识JAX-WS近期的项目工作涉及大量的接口测试,接口是基于Soap协议的Webservice接口。之前测试是使用Soapui进行接口测试,由于接口中涉及大量的变量需要填写或修改,深深的感到总是做着重复

    2022年7月1日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号