我可以使用JavaScript中的数组方法以更好的方式(更短)重写内部条件和方法调用的双循环吗?
listA.forEach(a => {
listB.forEach(b => {
if (a.name === b.name) {
a.doSomething(b);
}
});
});
答案 0 :(得分:0)
不确定会更好,但是您可以执行以下操作:
listA
.map(a => listB.map(b => ({ a, b }))) // Create Pairs of { a, b }
.reduce((r, a) => a.concat(r)) // flatten { a, b }[][] to { a, b }[]
.filter(o => o.a == o.b) // filter the list
.forEach(o => o.a.doSomething(o.b)); // call the function
答案 1 :(得分:0)
您可以将if
语句更改为:
a.name === b.name && a.doSomething(b);
Idk,如果这是您想要的更好/更短的产品。它使用short-circuit evaluation。
答案 2 :(得分:-1)
没有什么地方比这更短了,但也许更具可读性,并且它是没有所有这些嵌套循环的一种执行javascript的流式方式:
listA
.filter(a => listB.map(b => b.name).includes(a.name))
.forEach(a => {
console.log(a) // do your stuff here :)
})