數(shù)組實(shí)例的find方法,用于找出第一個(gè)符合條件的數(shù)組成員臣疑。它的參數(shù)是一個(gè)回調(diào)函數(shù)盔憨,所有數(shù)組成員依次執(zhí)行該回調(diào)函數(shù),直到找出第一個(gè)返回值為true的成員讯沈,然后返回該成員般渡。如果沒(méi)有符合條件的成員,則返回undefined芙盘。
[1, 4, -5, 10].find((n) => n < 0)
// -5
上面代碼找出數(shù)組中第一個(gè)小于 0 的成員。
[1, 5, 10, 15].find(function(value, index, arr) {
return value > 9;
}) // 10
上面代碼中脸秽,find方法的回調(diào)函數(shù)可以接受三個(gè)參數(shù)儒老,依次為當(dāng)前的值、當(dāng)前的位置和原數(shù)組记餐。
數(shù)組實(shí)例的findIndex方法的用法與find方法非常類似驮樊,返回第一個(gè)符合條件的數(shù)組成員的位置,如果所有成員都不符合條件片酝,則返回-1囚衔。
[1, 5, 10, 15].findIndex(function(value, index, arr) {
return value > 9;
}) // 2
這兩個(gè)方法都可以接受第二個(gè)參數(shù),用來(lái)綁定回調(diào)函數(shù)的this對(duì)象雕沿。
function f(v){
return v > this.age;
}
let person = {name: 'John', age: 20};
[10, 12, 26, 15].find(f, person); // 26
上面的代碼中练湿,find函數(shù)接收了第二個(gè)參數(shù)person對(duì)象,回調(diào)函數(shù)中的this對(duì)象指向person對(duì)象审轮。
另外肥哎,這兩個(gè)方法都可以發(fā)現(xiàn)NaN,彌補(bǔ)了數(shù)組的indexOf方法的不足疾渣。
[NaN].indexOf(NaN)
// -1
[NaN].findIndex(y => Object.is(NaN, y))
// 0
上面代碼中篡诽,indexOf方法無(wú)法識(shí)別數(shù)組的NaN成員,但是findIndex方法可以借助Object.is方法做到榴捡。