arr = [1,2,3];
arr.forEach(function(i){
// last iteration
});
Como pegar quando o loop termina? Eu posso fazer, if(i == 3)
mas posso não saber qual é o número do meu array.
arr = [1,2,3];
arr.forEach(function(i){
// last iteration
});
Como pegar quando o loop termina? Eu posso fazer, if(i == 3)
mas posso não saber qual é o número do meu array.
Respostas:
A resposta atualizada para ES6 + está aqui .
arr = [1, 2, 3];
arr.forEach(function(i, idx, array){
if (idx === array.length - 1){
console.log("Last callback call at index " + idx + " with value " + i );
}
});
produziria:
Last callback call at index 2 with value 3
A maneira como isso funciona é testando arr.length
contra o índice atual do array, passado para a função de retorno de chamada .
A RESPOSTA ES6 + 2018 É :
const arr = [1, 2, 3];
arr.forEach((val, key, arr) => {
if (Object.is(arr.length - 1, key)) {
// execute last item logic
console.log(`Last callback call at index ${key} with value ${val}` );
}
});
Object.is
para algo tão simples como soar dois inteiros (que não podem nem ser -0 ou NaN) é definitivamente confuso. Diga-me, @SterlingBourne, quais são os benefícios?
const arr= [1, 2, 3]
arr.forEach(function(element){
if(arr[arr.length-1] === element){
console.log("Last Element")
}
})
let o = { val:"ue" } ; let arr = [ o, 1, o ]; ...
infelizmente, a primeira iteração teráarr[arr.length-1] === element
arr
já está no escopo como um encerramento para cada retorno de chamada