Array.prototype.findIndex()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. Itâs been available across browsers since 2015å¹´9æ.
findIndex() 㯠Array ã¤ã³ã¹ã¿ã³ã¹ã®ã¡ã½ããã§ãé
åå
ã®æå®ããããã¹ã颿°ã«åæ ¼ããæåã®è¦ç´ ã®ã¤ã³ããã¯ã¹ãè¿ãã¾ãã
ãã¹ã颿°ã«åæ ¼ããè¦ç´ ããªãã£ãå ´å㯠-1 ãè¿ãã¾ãã
find() ã¡ã½ãããåç
§ãã¦ãã ããããã¡ãã®ã¡ã½ããã¯ãé
åå
ã§è¦ã¤ãã£ãè¦ç´ ã®ä½ç½®ã§ã¯ãªããå¤ãè¿ãã¾ãã
試ãã¦ã¿ã¾ããã
const array = [5, 12, 8, 130, 44];
const isLargeNumber = (element) => element > 13;
console.log(array.findIndex(isLargeNumber));
// äºæ³ãããçµæ: 3
æ§æ
findIndex(callbackFn)
findIndex(callbackFn, thisArg)
弿°
callbackFn-
é åã®ããããã®è¦ç´ ã«å¯¾ãã¦å®è¡ãã颿°ã§ããä¸è´ããè¦ç´ ãå¾ããããã¨ã示ãã«ã¯çå¤ãè¿ããããã§ãªããã°å½å¤ãè¿ãã¦ãã ããããã®é¢æ°ã¯ä»¥ä¸ã®å¼æ°ã§å¼ã³åºããã¾ãã
thisArgçç¥å¯-
callbackFnå ã§thisã¨ãã¦ä½¿ããããªãã¸ã§ã¯ãã§ããå復å¦çã¡ã½ãããåç §ãã¦ãã ããã
è¿å¤
ãã¹ãã«åæ ¼ããé
åã®è¦ç´ ã®ä½ç½®ãè¿ãã¾ãããã以å¤ã®å ´åã¯ã -1 ãè¿ãã¾ãã
解説
findIndex() ã¡ã½ããã¯å復å¦çã¡ã½ããã§ããé
åã®è¦ç´ ã®ããããã«å¯¾ãã¦ãã¤ã³ããã¯ã¹ã®æé ã«ä¸åº¦ã㤠callbackFn 颿°ãå®è¡ããcallbackFn 颿°ãçå¤ãè¿ãã¾ã§ç¹°ãè¿ãã¾ãã findIndex() ã¯ãã®è¦ç´ ãè¿ããé
åã®å復å¦çã忢ãã¾ãããã callbackFn ãçå¤ãè¿ããªãå ´åã findIndex() 㯠-1 ãè¿ãã¾ãããããã®ã¡ã½ãããä¸è¬çã«ã©ã®ããã«åä½ããã®ãã«ã¤ãã¦ã®è©³ç´°ã¯ãå復å¦çã¡ã½ããã®ç¯ãã覧ãã ããã
callbackFn ã¯ãå¤ãå²ãå½ã¦ããã¦ãããã®ã«éãããé
åä¸ã®ãã¹ã¦ã®ã¤ã³ããã¯ã¹ã«å¯¾ãã¦å¼ã³åºããã¾ããçé
åã§ã¯ã空ã®ã¹ããã㯠undefined ã¨åãåä½ããã¾ãã
findIndex() ã¡ã½ããã¯æ±ç¨çã§ãããã㯠this å¤ã« length ããããã£ã¨æ´æ°ãã¼ã®ããããã£ããããã¨ã ããæå¾
ãã¾ãã
ä¾
>é åå ã®æåã®ç´ æ°ã®ä½ç½®ãæ¤ç´¢ãã
次ã®ä¾ã§ã¯ãé
åã®ä¸ã§ç´ æ°ã®å
¥ã£ãæåã®è¦ç´ ã®ä½ç½®ãè¿ããç´ æ°ãè¦ã¤ãããªãã£ãå ´å㯠-1 ãè¿ãã¾ãã
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, 9, 12].findIndex(isPrime)); // -1, not found
console.log([4, 6, 7, 9, 12].findIndex(isPrime)); // 2 (array[2] is 7)
ã¡ã¢:
isPrime() ã®å®è£
ã¯ã説æã®ã¿ãç®çã¨ãã¦ãã¾ããå®éã®ã¢ããªã±ã¼ã·ã§ã³ã§ã¯ãç¹°ãè¿ãè¨ç®ãé¿ããããã«ãã¨ã©ãã¹ããã¹ã®ç¯©ãªã©ã®ãé«åº¦ã«æé©åãããã¢ã«ã´ãªãºã ã使ç¨ãããã¨ããå§ããã¾ãã
callbackFn ã®ç¬¬ 3 弿°ã®ä½¿ç¨
array 弿°ã¯ãé
åå
ã®å¥ã®è¦ç´ ã«ã¢ã¯ã»ã¹ããå ´åãç¹ã«ããã®é
åãåç
§ããæ¢åã®å¤æ°ããªãå ´åã«ä¾¿å©ã§ããæ¬¡ã®ä¾ã§ã¯ãæåã« filter() ã使ç¨ãã¦æ£ã®å¤ãæ½åºããæ¬¡ã« findIndex() ã使ç¨ãã¦ããã®å¤ãããå°ããæåã®è¦ç´ ãæ¢ãã¾ãã
const numbers = [3, -1, 1, 4, 1, 5, 9, 2, 6];
const firstTrough = numbers
.filter((num) => num > 0)
.findIndex((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(firstTrough); // 1
çé åã«ããã findIndex() ã®ä½¿ç¨
çé
åã§ undefined ãæ¤ç´¢ãããã¨ã§ã空ã¹ãããã®ã¤ã³ããã¯ã¹ãåå¾ãããã¨ãã§ãã¾ãã
console.log([1, , 3].findIndex((x) => x === undefined)); // 1
é åã§ãªããªãã¸ã§ã¯ãã«å¯¾ãã findIndex() ã®å¼ã³åºã
findIndex() ã¡ã½ãã㯠this ã® length ããããã£ãèªã¿è¾¼ã¿ããã®ãã¼ã length ãããå°ããéè² ã®æ´æ°ã§ããåããããã£ã«ã¢ã¯ã»ã¹ãã¾ãã
const arrayLike = {
length: 3,
"-1": 0.1, // -1 < 0 ãªã®ã§ findIndex() 空ã¯ç¡è¦ããã
0: 2,
1: 7.3,
2: 4,
};
console.log(
Array.prototype.findIndex.call(arrayLike, (x) => !Number.isInteger(x)),
); // 1
仿§æ¸
| Specification |
|---|
| ECMAScript® 2027 Language Specification> # sec-array.prototype.findindex> |
ãã©ã¦ã¶ã¼ã®äºææ§
é¢é£æ å ±
Array.prototype.findIndexã®ããªãã£ã« (core-js)- es-shims ã«ãã
Array.prototype.findIndexã®ããªãã£ã« - ã¤ã³ããã¯ã¹ä»ãã³ã¬ã¯ã·ã§ã³ã®ã¬ã¤ã
ArrayArray.prototype.find()Array.prototype.findLast()Array.prototype.findLastIndex()Array.prototype.indexOf()Array.prototype.lastIndexOf()TypedArray.prototype.findIndex()