码农知识堂 - 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
  • 相关阅读:
    一套Altair Feko复杂结构模型散射和天线辐射仿真建模攻略
    黑猫带你学UFS协议第16篇:UFS命令队列详解(CMDQ)
    开发工程师必备————【Day16】数据库知识补充
    多商户商城系统功能拆解16讲-平台端会员成长值记录
    Uniapp 酷炫钱包页面模板 直接引用
    【Redis】使用Java客户端操作Redis
    jsp监考安排管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
    [C#基础训练]FoodRobot食品管理部分代码-2
    Go语言的流程控制
    Python中定义Mittag-Leffler函数
  • 原文地址: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号