forEach 在 javascript 中同时循环遍历两个数组

Fil*_*ira 24 javascript foreach for-loop vue.js

我想构建一个for同时遍历两个变量的循环。n是一个数组,j从 0 到 16。

var n = [1,2,3,5,7,8,9,11,12,13,14,16,17,18,20,21,22];
var m = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16];

m.forEach(k => {
    n.forEach(i => {
        console.log(i, k)
    });
};
Run Code Online (Sandbox Code Playgroud)

最终结果应该输出:

1,0
2,1
3,2
5,3
(...)
Run Code Online (Sandbox Code Playgroud)

不幸的是,这个循环由于某种原因没有这样做,因为它每个数字重复 17 次。

我在这里缺少什么?

Cer*_*nce 44

改用第二个参数forEachaccepts ,这将是您正在迭代的当前索引:

n = [1,2,3,5,7,8,9,11,12,13,14,16,17,18,20,21,22];

n.forEach((element, index) => {
  console.log(element, index);
});
Run Code Online (Sandbox Code Playgroud)

如果您有两个单独的数组开始,在每次迭代中,访问[index]另一个数组的属性:

var n = [1, 2, 3, 5, 7, 8, 9, 11, 12, 13, 14, 16, 17, 18, 20, 21, 22];
var m = [0, 1, 2, 3, 4, 5, 6, 7,  8,  9,  10, 11, 12, 13, 14, 15, 16];

n.forEach((num1, index) => {
  const num2 = m[index];
  console.log(num1, num2);
});
Run Code Online (Sandbox Code Playgroud)

  • 这确实有效。现在想象一下我想要一个特定的数组而不是索引。我编辑了这篇文章以反映这一点。 (2认同)