码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 详解JS遍历对象的五种方法


    前言

    本文主要讲解Js遍历Object对象的几种方法,下面请出本次出场嘉宾:

    	let person={name:'Jack',age:18,sex:'man'}
    
    • 1

    有几种方法能让person对象遍历呢,让我们往下看。

    for in方法

    for(item in person){
    	console.log(person[item]);//Jack 18 man
    }
    
    • 1
    • 2
    • 3

    for in方法可以遍历我们的对象,它能获取到对象中的所有属性名,而对象就可以根据这个属性名,来调用对应的属性值。

    Object.keys结合for of方法

    首先我们明确一个事情,Object.key是用来获取该对象的所有属性名,并把这些值变成一个新数组,主要数组对象使用,普通对象也可以使用,而for of正好也被数组应用,返回的是数组的属性值,那么就可以让两者结合实现属性值的遍历。

    for(item of Object.keys(person)){
    	console.log(person[item]);
    }
    
    • 1
    • 2
    • 3

    首先Object.keys(person)打印出来的是[name,age,sex],这三个对象属性名,再由of遍历出来,在放在person的属性名item上,则可以调用出来属性值。

    Object.values结合for of方法

    values方法打印的直接就是这个对象的属性值,并封装成数组,所以无需使用person进行调用,直接for of即可调用出来所有person的属性值。

    for(item of Object.values(person)){
    	console.log(item);
    }
    
    • 1
    • 2
    • 3

    Object.entries结合for of方法

    entries方法打印出来的是对象的键值对,也就是属性值和属性名都有,也就是把对象彻底变成map键值对的结构,并封装在数组中,属性值通常在属性名后面,那么在for of遍历中,就可以通过item[1]遍历出来想要的属性值。

    for(item of Object.entries(person)){
    	console.log(item[1]);
    }
    
    • 1
    • 2
    • 3

    getOwnPropertyNames和for of

    getOwnPropertyNames和keys方法功能一样,它还有length属性,这也意味着它不能转换不能枚举的对象,也就是不能获取长度的对象。它也是获取所有属性名,并封装成一个数组。

    for(item of Object.getOwnPropertyNames(person)){
    	console.log(person[item]);
    }
    
    • 1
    • 2
    • 3
  • 相关阅读:
    BTree vs B+Tree 节点操作流程图解
    Git开发、发布、缺陷分离模型概述(支持master/develop/feature/release/hotfix类型分支)
    mybatis中的og表达式都支持哪些 支持or and 传值是数字无所谓加不加‘ ‘ 传值为字符串必须加 ‘ ‘
    JavaScript 67 JavaScript HTML DOM 67.1 DOM 简介
    将dumpbin从VS中抠出来,并使用dumpbin查看exe和dll库的依赖关系
    所求和问题
    MySQL运维12-Mycat分库分表之按天分片
    html5 列表/表格标签
    全国护眼工程大会|2023山东哺光仪展|近视眼镜展|眼视光展
    8.会话跟踪技术
  • 原文地址:https://blog.csdn.net/lplovewjm/article/details/134520941
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号