Skip to content

小技巧:for of中获取index

日常开发中在遍历数据时经常使用for...of,forEach

前者使用时能够配合async await,continue,break等等

ts
const data = [
  { name: 'xm1', age: 1 },
  { name: 'xm2', age: 4 },
  { name: 'xm3', age: 5 },
  { name: 'xm4', age: 9 }
]

function sleep(s){
  const end = s * 1000 + Date.now()
  while(Date.now() < end){}
}
async function fn(){
  for (const people of data) {
    if (people.age === 9) {
      break
    }
    if (people.age % 2 !== 0) {
      continue
    }
    await sleep(people.age)
    console.log(people.name);
  }
} 
fn() // xm2
const data = [
  { name: 'xm1', age: 1 },
  { name: 'xm2', age: 4 },
  { name: 'xm3', age: 5 },
  { name: 'xm4', age: 9 }
]

function sleep(s){
  const end = s * 1000 + Date.now()
  while(Date.now() < end){}
}
async function fn(){
  for (const people of data) {
    if (people.age === 9) {
      break
    }
    if (people.age % 2 !== 0) {
      continue
    }
    await sleep(people.age)
    console.log(people.name);
  }
} 
fn() // xm2

但有时候想获取元素的idx,有哪些简单的方式呢

1-Array.prototype.map

ts
function MapWithIdx(arr){
    return arr.map((v, idx) => ([idx, v]))
}

for (const [idx, v] of MapWithIdx(data)) {
  console.log(idx, v);
}
function MapWithIdx(arr){
    return arr.map((v, idx) => ([idx, v]))
}

for (const [idx, v] of MapWithIdx(data)) {
  console.log(idx, v);
}

2-Array.prototype.entries

这个方法是ES6新增的API

ts
for (const [idx, v] of data.entries()) {
  console.log(idx, v);
}
for (const [idx, v] of data.entries()) {
  console.log(idx, v);
}

3-Array.prototype.keys

这个方法也是ES6新增的API

ts
for (const idx of data.keys()) {
    const v = data[idx]
    console.log(idx, v);
}
for (const idx of data.keys()) {
    const v = data[idx]
    console.log(idx, v);
}

更新于: