for..in 与 for..of 的可使用范围

for 的常见使用方式

前言

数组原生具备iterator接口(即默认部署了Symbol.iterator属性),for…of循环本质上就是调用这个接口产生的遍历器:

const arr = ['apple', 'watermelon', 'grape'];

for(v of arr) {
  console.log(v); // apple watermelon grape
}

const obj = {};
obj[Symbol.iterator] = arr[Symbol.iterator].bind(arr);

for(v of obj) {
  console.log(v); // apple watermelon grape
}

概括

  • for…of循环可以使用的范围包括数组、SetMap 结构、某些类似数组的对象(比如arguments对象、DOM NodeList 对象)、 Generator 对象,以及字符串。

  • JavaScript 原有的for...in循环,只能获得对象的键名,不能直接获取键值。ES6 提供for...of循环,允许遍历获得键值。(如1、2)

在这里插入图片描述

示例

  • let 是用于声明块级作用域的变量,在 for...in 循环的每一次迭代中都是一个独立的块级作用域变量。

  • 这与 var 不同,var 会将变量提升到函数或全局作用域。

  1. for…in 遍历数字数组

    let arr = [9,8,7,1,2,3,4,5,6,7,8];
    
    for(key in arr) {
        console.log(key)
    }
    // console
    "0"
    "1"
    "2"
    "3"
    "4"
    "5"
    "6"
    "7"
    "8"
    
  2. for…of 遍历数字数组

    let arr = [9,8,7,1,2,3,4,5,6,7,8];
    
    for(value of arr) {
        console.log(value)
    }
    // console
    9
    8
    7
    1
    2
    3
    4
    5
    6
    7
    8
    
  3. for…of遍历对象数组

     let arr2 = [
         {name: 'zs', age: 18},
         {name: 'ls', age: 12},
         {name: 'ww', age: 13},
         {name: 'zl', age: 14},
         {name: 'qy', age: 22},
     ]
    
     for(value of arr2) {
         console.log(value)
     }
     // console
     {
         age: 18,
         name: "zs"
     }
     {
         age: 12,
         name: "ls"
     }
     {
         age: 13,
         name: "ww"
     }
     {
         age: 14,
         name: "zl"
     }
     {
         age: 22,
         name: "qy"
     }
    
  4. for…in遍历对象

    for...in 循环用于遍历对象的可枚举属性(包括从原型链继承的属性)。

    let obj = {a:1,b:2,c:3}
    
    for(item in obj) {
        console.log(item)
    }
    // console
    "a"
    "b"
    "c"
    
  5. for…in遍历对象

    for...in 循环用于遍历对象的可枚举属性(包括从原型链继承的属性)。

    let obj2 = {
        a: {x:1,s:2},
        b: {x:11,s:22},
        c: {x:111,s:222},
    }
    
    for(key in obj2) {
        console.log(key,obj2[key])
    }
    // console
    "a", { s: 2, x: 1 }
    "b", { s: 22, x: 11 }
    "c", { s: 222, x: 111 }
    
  6. for…in遍历字符串

    let str = 'Hello JavaScript'
    
    for(s in str) {
        console.log(s)
    }
    // console
    "0"
    "1"
    "2"
    "3"
    "4"
    "5"
    "6"
    "7"
    "8"
    "9"
    "10"
    "11"
    "12"
    "13"
    "14"
    "15"
    
  7. for…of遍历字符串

    let str = 'Hello JavaScript'
    
    for(s of str) {
        console.log(s)
    }
    // console
    "H"
    "e"
    "l"
    "l"
    "o"
    " "
    "J"
    "a"
    "v"
    "a"
    "S"
    "c"
    "r"
    "i"
    "p"
    "t"
    
  8. for…of遍历键值对

    let map = new Map([
        ['a', 1],
        ['b', 2],
        ['c', 3]
    ])
    
    for(m of map) {
        console.log(m)
    }
    // console
    ["a", 1]
    ["b", 2]
    ["c", 3]
    
    // 返回键名的遍历器
    for(k of map.keys()) {
        console.log(k)
    }
    // console
    "a"
    "b"
    "c"
    
    // 返回键值的遍历器
    for(v of map.values()) {
        console.log(v)
    }
    // console
    1
    2
    3
    
    
    // 返回所有成员的遍历器
    for([key,value] of map.entries()) {
        console.log(key,value)
    }
    // 等同于
    for([key,value] of map) {
        console.log(key,value)
    }
    // console
    "a", 1
    "b", 2
    "c", 3
    
  9. for…of遍历数据结构 Set

    const set = new Set([1, 2, 3, 4, 4]);
    
    for(value of set) {
        console.log(value)
    }
    // console
    1
    2
    3
    4
    

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vinca@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值