码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • for in 、for of详解


    文章目录

      • for in
        • 可以用在可枚举数据 => 对象
        • 可枚举数据
        • 示例
      • for of
        • 可以用在可迭代数据 => 数组、字符串、Map、Set
        • 可迭代数据
        • 示例

    for in

    可以用在可枚举数据 => 对象

    可枚举数据

    属性描述符 => enumerable

    示例

    1、可以用来遍历对象 => 属性名
    如:
    在这里插入图片描述
    上面有个enumerable属性,就是它来控制属性是否可枚举

    同时也会枚举对象原型上的可枚举的属性名

    let obj = {
        name: "lihegui",
        gender: "nan",
        age: "22"
    }
    for (let item in obj) {
        console.log(item);
    }
    //	name
    //	gender
    //	age
    

    2、可以用来遍历数组 => 数组下标

    let arr = ["lihegui", "fxp", "shuzu"]
    for (let item in arr) {
        console.log(item);
    }
    //	0
    //	1
    //	2
    

    3、遍历字符串 => 字符所处的位置下标

    let str = "lihegui"
    for (let item in str) {
        console.log(item);
    }
    //	0
    //	1
    //	2
    //	3
    //	4
    //	5
    //	6
    

    for of

    可以用在可迭代数据 => 数组、字符串、Map、Set

    for in 遍历map set会是undefined

    可迭代数据

    只要一个数据实现Iterator接口,这个数据就会有一个叫做[Symbol.iterator]的属性
    例如数组有个Synbol.iterator的属性

    示例

    1、遍历数组 => 数组每一项

    let arr = ["lihegui", ["and", "lihegui"], "fxp", "shuzu"]
    for (let item of arr) {
        console.log(item);
    }
    //	lihegui
    //	['and','lihegui']
    //	fxp
    //	shuzu
    

    2、遍历字符串 => 字符每一项

    let str = "lihegui"
    for (let item of str) {
        console.log(item);
    }
    //	l
    //	i
    //	h
    //	e
    //	g
    //	u
    //	i
    

    3、遍历map => 每一项

    let map = new Map([
        [1, 'one'],
        [2, 'two'],
        [3, 'three']
    ])
    for (let item of map) {
        console.log(item);
    }
    //	[ 1, 'one' ]
    //	[ 2, 'two' ]
    //	[ 3, 'three' ]
    

    4、遍历set => 每一项

    let set = new Set(["lihegui", "fxp"])
    for (let item of set) {
        console.log(item);
    }
    //	lihegui
    //	fxp
    
  • 相关阅读:
    ROS机械臂 Movelt 学习笔记1 | 基础准备
    C陷阱与缺陷 第7章 可移植性缺陷 7.2 标识符名称的限制
    风控数据(模型)不扎心,只因好这道流水工序上的处理技巧
    flutter 增加 https 支持
    【Java 进阶篇】HTML DOM样式控制详解
    大语言模型微调实践——LoRA 微调细节
    .NET 断点上传
    【前端学习】—判断成立(十二)
    如何解压 GZ 文件
    lammps技巧:Out of range atoms - cannot compute PPPM原因分析及解决办法
  • 原文地址:https://blog.csdn.net/qq_45859670/article/details/127042208
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号