arr = [1,2,3];
arr.forEach(function(i){
// last iteration
});
Làm thế nào để bắt khi vòng lặp kết thúc? Tôi có thể làm if(i == 3)
nhưng tôi có thể không biết số mảng của tôi là gì.
arr = [1,2,3];
arr.forEach(function(i){
// last iteration
});
Làm thế nào để bắt khi vòng lặp kết thúc? Tôi có thể làm if(i == 3)
nhưng tôi có thể không biết số mảng của tôi là gì.
Câu trả lời:
Câu trả lời cập nhật cho ES6 + là ở đây .
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 );
}
});
sẽ xuất:
Last callback call at index 2 with value 3
Cách thức hoạt động của điều này là kiểm tra arr.length
chỉ số hiện tại của mảng, được chuyển cho hàm gọi lại .
CÂU TRẢ LỜI ES6 + 2018 LÀ :
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}` );
}
});
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 ]; ...
tiếc là lần lặp đầu tiên sẽ cóarr[arr.length-1] === element
arr
đã nằm trong phạm vi như một đóng cho mỗi callback