Array.prototype.findLast()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. Itâs been available across browsers since 2022å¹´8æ.
findLast() 㯠Array ã¤ã³ã¹ã¿ã³ã¹ã®ã¡ã½ããã§ãé
åãéé ã«å復å¦çããæå®ããããã¹ã颿°ãæºããæåã®è¦ç´ ã®å¤ãè¿ãã¾ãã
ãã¹ã颿°ãæºããè¦ç´ ããªãå ´å㯠undefined ãè¿ããã¾ãã
æ¤ç´¢ãè¡ãå ´åã¯ä»¥ä¸ã®ã¡ã½ãããå¿ è¦ã§ãã
- ä¸è´ããæåã®è¦ç´ ãå¾ãã«ã¯ã
find()ã使ç¨ãã¦ãã ããã - é
åå
ã§ä¸è´ããæå¾ã®ä½ç½®ãå¾ãã«ã¯ã
findLastIndex()ã使ç¨ãã¦ãã ããã - å¤ã®ä½ç½®ãå¾ãã«ã¯ã
indexOf()ã使ç¨ãã¦ãã ããã ï¼ããã¯findIndex()ã«ä¼¼ã¦ãã¾ããããã¹ã颿°ã使ç¨ããã®ã§ã¯ãªããããããã®è¦ç´ ãå¤ã¨çãããã©ããã調ã¹ã¾ããï¼ - é
åã«å¤ãåå¨ãããã©ããã調ã¹ãã«ã¯ã
includes()ã使ç¨ãã¦ãã ããã ãã¡ããããã¹ã颿°ã使ç¨ãã代ããã«ãåè¦ç´ ãå¤ã¨çãããã©ããã調ã¹ã¾ãã - æå®ããããã¹ã颿°ãæºããè¦ç´ ãå¾ãã«ã¯
some()ã使ç¨ãã¦ãã ããã
試ãã¦ã¿ã¾ããã
const array = [5, 12, 50, 130, 44];
const found = array.findLast((element) => element > 45);
console.log(found);
// äºæ³ãããçµæ: 130
æ§æ
findLast(callbackFn)
findLast(callbackFn, thisArg)
弿°
callbackFn-
é åã®ããããã®è¦ç´ ã«å¯¾ãã¦å®è¡ãã颿°ã§ããä¸è´ããè¦ç´ ãå¾ããããã¨ã示ãã«ã¯çå¤ãè¿ããããã§ãªããã°å½å¤ãè¿ãã¦ãã ããããã®é¢æ°ã¯ä»¥ä¸ã®å¼æ°ã§å¼ã³åºããã¾ãã
thisArgçç¥å¯-
callbackFnå ã§thisã¨ãã¦ä½¿ããããªãã¸ã§ã¯ãã§ããå復å¦çã¡ã½ãããåç §ãã¦ãã ããã
è¿å¤
æå®ããããã¹ã颿°ãæºãããé
åä¸ã®æã大ããã¤ã³ããã¯ã¹å¤ãæã¤è¦ç´ ã®å¤ãä¸è´ããè¦ç´ ãè¦ã¤ãããªãå ´å㯠undefined ã¨ãªãã¾ãã
解説
findLast() ã¡ã½ããã¯å復å¦çã¡ã½ããã§ããé
åã®è¦ç´ ã®ããããã«å¯¾ãã¦ãã¤ã³ããã¯ã¹ã®éé ã«ä¸åº¦ã㤠callbackFn 颿°ãå®è¡ããcallbackFn 颿°ãçå¤ãè¿ãã¾ã§ç¹°ãè¿ãã¾ãã findLast() ã¯ãã®è¦ç´ ãè¿ããé
åã®å復å¦çã忢ãã¾ãããã callbackFn ãçå¤ãè¿ããªãå ´åã findLast() 㯠undefined ãè¿ãã¾ãããããã®ã¡ã½ãããä¸è¬çã«ã©ã®ããã«åä½ããã®ãã«ã¤ãã¦ã®è©³ç´°ã¯ãå復å¦çã¡ã½ããã®ç¯ãã覧ãã ããã
callbackFn ã¯ãå¤ãå²ãå½ã¦ããã¦ãããã®ã«éãããé
åä¸ã®ãã¹ã¦ã®ã¤ã³ããã¯ã¹ã«å¯¾ãã¦å¼ã³åºããã¾ããçé
åã§ã¯ã空ã®ã¹ããã㯠undefined ã¨åãåä½ããã¾ãã
findLast() ã¡ã½ããã¯æ±ç¨çã§ãããã㯠this å¤ã« length ããããã£ã¨æ´æ°ãã¼ã®ããããã£ããããã¨ã ããæå¾
ãã¾ãã
ä¾
>è¦ç´ ã®ããããã£ã«ä¸è´ããé åã®æå¾ã®ãªãã¸ã§ã¯ããæ¢ã
ãã®ä¾ã§ã¯ãé åè¦ç´ ã®ããããã£ã«åºã¥ãããã¹ãã使ããæ¹æ³ã示ãã¾ãã
const inventory = [
{ name: "apples", quantity: 2 },
{ name: "bananas", quantity: 0 },
{ name: "fish", quantity: 1 },
{ name: "cherries", quantity: 5 },
];
// å¨åº«ããªãå ´åã¯çå¤ãè¿ã
function isNotEnough(item) {
return item.quantity < 2;
}
console.log(inventory.findLast(isNotEnough));
// { name: "fish", quantity: 1 }
ã¢ãã¼é¢æ°ã¨æ§é åè§£ã®ä½¿ç¨
å ã®ä¾ã¯ãã¢ãã¼é¢æ°ã¨ãªãã¸ã§ã¯ãã®æ§é åè§£ã使ç¨ãã¦æ¸ããã¨ãã§ããããããã¾ããã
const inventory = [
{ name: "apples", quantity: 2 },
{ name: "bananas", quantity: 0 },
{ name: "fish", quantity: 1 },
{ name: "cherries", quantity: 5 },
];
const result = inventory.findLast(({ quantity }) => quantity < 2);
console.log(result);
// { name: "fish", quantity: 1 }
é åä¸ã®æå¾ã®ç´ æ°ãæ¢ã
以ä¸ã®ä¾ã§ã¯ãé
åã®æå¾ã®è¦ç´ ã§ç´ æ°ã®æå¾ã®è¦ç´ ãè¿ãã¾ããç´ æ°ããªãå ´å㯠undefined ãè¿ãã¦ãã¾ãã
function isPrime(n) {
if (n < 2) {
return false;
}
if (n % 2 === 0) {
return n === 2;
}
for (let factor = 3; factor * factor <= n; factor += 2) {
if (n % factor === 0) {
return false;
}
}
return true;
}
console.log([4, 6, 8, 12].findLast(isPrime)); // undefined, not found
console.log([4, 5, 7, 8, 9, 11, 12].findLast(isPrime)); // 11
ã¡ã¢:
isPrime() ã®å®è£
ã¯ã説æã®ã¿ãç®çã¨ãã¦ãã¾ããå®éã®ã¢ããªã±ã¼ã·ã§ã³ã§ã¯ãç¹°ãè¿ãè¨ç®ãé¿ããããã«ãã¨ã©ãã¹ããã¹ã®ç¯©ãªã©ã®ãé«åº¦ã«æé©åãããã¢ã«ã´ãªãºã ã使ç¨ãããã¨ããå§ããã¾ãã
callbackFn ã®ç¬¬ 3 弿°ã®ä½¿ç¨
array 弿°ã¯ãé
åå
ã®å¥ã®è¦ç´ ã«ã¢ã¯ã»ã¹ããå ´åãç¹ã«ããã®é
åãåç
§ããæ¢åã®å¤æ°ããªãå ´åã«ä¾¿å©ã§ããæ¬¡ã®ä¾ã§ã¯ãæåã« filter() ã使ç¨ãã¦æ£ã®å¤ãæ½åºããæ¬¡ã« findLast() ã使ç¨ãã¦ããã®é£ãããå°ããæå¾ã®è¦ç´ ãæ¢ãã¾ãã
const numbers = [3, -1, 1, 4, 1, 5, 9, 2, 6];
const lastTrough = numbers
.filter((num) => num > 0)
.findLast((num, idx, arr) => {
// arr 弿°ããªãå ´åã夿°ã«ä¿åããã«ä¸éé
åã«ç°¡åã«
// ã¢ã¯ã»ã¹ããæ¹æ³ã¯ããã¾ããã
if (idx > 0 && num >= arr[idx - 1]) return false;
if (idx < arr.length - 1 && num >= arr[idx + 1]) return false;
return true;
});
console.log(lastTrough); // 2
findLast() ãçé åã§ä½¿ç¨
çé
åã®ç©ºã®ã¹ãããã¯å¦çããã undefined ã¨åãããã«æ±ããã¾ãã
// ã¤ã³ããã¯ã¹ 2ã3ã4 ã«è¦ç´ ããªãé
åã®å®£è¨
const array = [0, 1, , , , 5, 6];
// å¤ãå²ãå½ã¦ããã¦ããã¤ã³ããã¯ã¹ã ãã§ãªãããã¹ã¦ã®ã¤ã³ããã¯ã¹ã表示
array.findLast((value, index) => {
console.log(`Visited index ${index} with value ${value}`);
return false;
});
// Visited index 6 with value 6
// Visited index 5 with value 5
// Visited index 4 with value undefined
// Visited index 3 with value undefined
// Visited index 2 with value undefined
// Visited index 1 with value 1
// Visited index 0 with value 0
// åé¤ãããã¤ã³ããã¯ã¹ãå«ãããã¹ã¦ã®ã¤ã³ããã¯ã¹ã表示
array.findLast((value, index) => {
// Delete element 5 on first iteration
if (index === 6) {
console.log(`Deleting array[5] with value ${array[5]}`);
delete array[5];
}
// è¦ç´ 5 ã¯åé¤ãããã«ãããããããå¦çããã
console.log(`Visited index ${index} with value ${value}`);
return false;
});
// Deleting array[5] with value 5
// Visited index 6 with value 6
// Visited index 5 with value undefined
// Visited index 4 with value undefined
// Visited index 3 with value undefined
// Visited index 2 with value undefined
// Visited index 1 with value 1
// Visited index 0 with value 0
é åã§ãªããªãã¸ã§ã¯ãã«å¯¾ãã findLast() ã®å¼ã³åºã
findLast() ã¡ã½ãã㯠this ã® length ããããã£ãèªã¿è¾¼ã¿ã次ã«ãã¼ã length ããå°ããéè² ã®æ´æ°ã§ããåããããã£ã«ã¢ã¯ã»ã¹ãã¾ãã
const arrayLike = {
length: 3,
0: 2,
1: 7.3,
2: 4,
3: 3, // length ã 3 ãªã®ã§ findLast() ã¯ç¡è¦ããã
};
console.log(
Array.prototype.findLast.call(arrayLike, (x) => Number.isInteger(x)),
); // 4
仿§æ¸
| Specification |
|---|
| ECMAScript® 2027 Language Specification> # sec-array.prototype.findlast> |
ãã©ã¦ã¶ã¼ã®äºææ§
é¢é£æ å ±
Array.prototype.findLastã®ããªãã£ã« (core-js)- es-shims ã«ãã
Array.prototype.findLastã®ããªãã£ã« - ã¤ã³ããã¯ã¹ä»ãã³ã¬ã¯ã·ã§ã³ã®ã¬ã¤ã
ArrayArray.prototype.find()Array.prototype.findIndex()Array.prototype.findLastIndex()Array.prototype.includes()Array.prototype.filter()Array.prototype.every()Array.prototype.some()TypedArray.prototype.findLast()