數組實例的 find() 和 findIndex()
數組實例的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
方法做到。