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

陣列例項的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方法做到。