for in

以任意顺序遍历一个对象的可枚举属性 (opens new window)。遍历数组时,key为数组下标字符串;遍历对象,key为对象字段名。

**#数组**

let arr = [{age: 1}, {age: 5}, {age: 100}, {age: 34}] for (let key in arr) { console.log(key, arr[key]) } // 打印 // 0 {age: 1} // 1 {age: 5} // 2 {age: 100} // 3 {age: 34}

**#对象**

let obj = {f1: 'test1', f2: 'test2'} for (let key in obj) { console.log(key, obj[key]) } // 打印 // f1 test1 // f2 test2

**#for in 缺点**

  1. for in 迭代顺序依赖于执行环境,不一定保证顺序
  2. for in 不仅会遍历当前对象,还包括原型链上的可枚举属性
  3. for in 没有break中断
  4. for in 不适合遍历数组,主要应用为对象

**#for of**

ES6引入的新语法。在可迭代对象(包括 Array,Map,Set,String,TypedArray,arguments对象,NodeList对象)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。

Object对象不是可迭代对象,故for of 不支持。for of有个很大的特点是支持数组的break中断。

**#数组**

let arr = [{age: 1}, {age: 5}, {age: 100}, {age: 34}] for(let {age} of arr) { if (age > 10) { break // for of 允许中断 } console.log(age) } // 打印 // 1 // 5

**#for of 优点**

  1. for of 有与for in 一样的简洁语法(这也是两者容易混乱的点),但没有for in的缺点
  2. for of 保证顺序且不会仅遍历当前对象
  3. for of 可与break,continue,return配合