陣列例項的find()和findIndex()
阿新 • • 發佈:2019-01-31
陣列例項的find方法,用於找出第一符合條件的陣列成員。它的引數是一個回撥函式,所有的陣列成員依次執行該回調函式,直到找出第一個返回值為true的成員,然後返回該成員,如果沒有符合條件的成員,返回undefined。
[1, 4, -5, 10].find((n) => n < 0)
// -5
上面程式碼找出陣列中第一個小於 0 的成員。
[1, 5, 10, 15].find(function(value, index, arr) {
return value > 9;
}) // 10
上面程式碼中,find
方法的回撥函式可以接受三個引數,依次為當前的值、當前的位置和原陣列。
陣列例項的findIndex
方法的用法與find
方法非常類似,返回第一個符合條件的陣列成員的位置,如果所有成員都不符合條件,則返回-1
。
[1, 5, 10, 15].findIndex(function(value, index, arr) {
return value > 9;
}) // 2
這兩個方法都可以接受第二個引數,用來繫結回撥函式的this
物件。
function f(v){
return v > this.age;
}
let person = {name: 'John', age: 20};
[10, 12, 26, 15].find(f, person); // 26
上面的程式碼中,find
函式接收了第二個引數
person
物件,回撥函式中的this
物件指向person
物件。另外,這兩個方法都可以發現NaN
,彌補了陣列的indexOf
方法的不足。
[NaN].indexOf(NaN)
// -1
[NaN].findIndex(y => Object.is(NaN, y))
// 0
上面程式碼中,indexOf
方法無法識別陣列的NaN
成員,但是findIndex
方法可以藉助Object.is
方法做到。