2.ES6-陣列例項的 find() 和 findIndex()
阿新 • • 發佈:2021-10-26
陣列例項的 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
物件。
參考內容: