1. 程式人生 > >es6 陣列例項的 find() 和 findIndex()

es6 陣列例項的 find() 和 findIndex()

陣列例項的find方法,用於找出第一個符合條件的陣列成員。它的引數是一個回撥函式,所有陣列成員依次執行該回調函式,直到找出第一個返回值為true的成員,然後返回該成員。如果沒有符合條件的成員,則返回undefined。

[1, 4, -5, 10].find((n) => n < 0)
// -5
[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物件。
另外,這兩個方法都可以發現NaN,彌補了陣列的IndexOf方法的不足。
[NaN].indexOf(NaN)
// -1
[NaN].findIndex(y => Object.is(NaN, y))
// 0
上面程式碼中,indexOf方法無法識別陣列的NaN成員,但是findIndex方法可以藉助Object.is方法做到。