arr = [1,2,3];
arr.forEach(function(i){
// last iteration
});
จะจับได้อย่างไรเมื่อลูปจบลง? ฉันทำได้if(i == 3)
แต่ฉันอาจไม่รู้ว่าอาร์เรย์ของฉันคืออะไร
arr = [1,2,3];
arr.forEach(function(i){
// last iteration
});
จะจับได้อย่างไรเมื่อลูปจบลง? ฉันทำได้if(i == 3)
แต่ฉันอาจไม่รู้ว่าอาร์เรย์ของฉันคืออะไร
คำตอบ:
คำตอบที่อัปเดตสำหรับ ES6 + เป็นที่นี่
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 );
}
});
จะส่งออก:
Last callback call at index 2 with value 3
วิธีการทำงานนี้คือการทดสอบarr.length
กับดัชนีปัจจุบันของอาร์เรย์ที่ส่งผ่านไปยังฟังก์ชันการเรียกกลับ
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
อะไรง่ายๆอย่างการเปรียบเทียบจำนวนเต็มสองจำนวน (ซึ่งไม่สามารถเป็น -0 หรือ NaN ได้) นั้นยุ่งเหยิงที่สุด บอกฉันว่า @SterlingBourne มีประโยชน์อย่างไร?
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 ]; ...
น่าเสียดายที่การทำซ้ำครั้งแรกจะมีarr[arr.length-1] === element
arr
อยู่ในขอบเขตที่ปิดการโทรกลับแต่ละครั้งแล้ว