js中for in和for of的区别

1、直接遍历对象

在这里插入图片描述

for in 拿到的是对象的属性名,for of 直接报错

2、遍历数组:

for in 拿到的是数组对象的下标,for of 拿到的是数组对象的值
在这里插入图片描述

3、forEach

**forEach 循环无法中途跳出,break 命令或 return 命令都不能奏效

for…of 循环可以与break、continue 和 return 配合使用,跳出循环**

4、无论是 for…in 还是 for…of 都不能遍历出 Symbol 类型的值,

遍历 Symbol 类型的值需要用 Object.getOwnPropertySymbols() 方法

{
  let a = Symbol('a')
  let b = Symbol('b')

  let obj = {
    [a]: 'hello',
    [b]: 'world',
    c: 'es6',
    d: 'dom'
  }

  for(let key in obj) {
    console.info(key + ' --> ' + obj[key])
  }

  /*
    c --> es6
    d --> dom
  */

  let objSymbols = Object.getOwnPropertySymbols(obj)
  console.info(objSymbols)    //  [Symbol(a), Symbol(b)]
  objSymbols.forEach(item => {
    console.info(item.toString() + ' --> ' + obj[item])
  })

  /*
    Symbol(a) --> hello
    Symbol(b) --> world
  */

  // Reflect.ownKeys 方法可以返回所有类型的键名,包括常规键名和Symbol键名
  let keyArray = Reflect.ownKeys(obj)
  console.log(keyArray)      //  ["c", "d", Symbol(a), Symbol(b)]
}

总之,for…in 循环主要是为了遍历对象而生(直接拿到对象的属性名,再根据属性名获取属性值),不适用于遍历数组
for…of 循环可以用来遍历数组(直接获取数组的值)、类数组对象,字符串、Set、Map 以及 Generator 对象

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值