ES6中的數(shù)組實例 find() 和 findIndex()

數(shù)組實例的find方法,用于找出第一個符合條件的數(shù)組成員。它的參數(shù)是一個回調(diào)函數(shù),所有數(shù)組成員依次執(zhí)行該回調(diào)函數(shù),直到找出第一個返回值為true的成員,然后返回該成員。如果沒有符合條件的成員,則返回undefined。

[1, 4, -5, 10].find((n) => n < 0)
// -5

上面代碼找出數(shù)組中第一個小于 0 的成員。

[1, 5, 10, 15].find(function(value, index, arr) {
  return value > 9;
}) // 10

上面代碼中,find方法的回調(diào)函數(shù)可以接受三個參數(shù),依次為當(dāng)前的值、當(dāng)前的位置和原數(shù)組。

數(shù)組實例的findIndex方法的用法與find方法非常類似,返回第一個符合條件的數(shù)組成員的位置,如果所有成員都不符合條件,則返回-1。

[1, 5, 10, 15].findIndex(function(value, index, arr) {
  return value > 9;
}) // 2

這兩個方法都可以接受第二個參數(shù),用來綁定回調(diào)函數(shù)的this對象。

function f(v){
  return v > this.age;
}
let person = {name: 'John', age: 20};
[10, 12, 26, 15].find(f, person);    // 26

上面的代碼中,find函數(shù)接收了第二個參數(shù)person對象,回調(diào)函數(shù)中的this對象指向person對象。

另外,這兩個方法都可以發(fā)現(xiàn)NaN,彌補了數(shù)組的indexOf方法的不足。

[NaN].indexOf(NaN)
// -1

[NaN].findIndex(y => Object.is(NaN, y))
// 0

上面代碼中,indexOf方法無法識別數(shù)組的NaN成員,但是findIndex方法可以借助Object.is方法做到。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • [TOC] 參考阮一峰的ECMAScript 6 入門參考深入淺出ES6 let和const let和const都...
    郭子web閱讀 1,913評論 0 1
  • 1.Array.from Array.from方法用于將兩類對象轉(zhuǎn)為真正的數(shù)組:類似數(shù)組的對象(array-lik...
    趙然228閱讀 732評論 0 0
  • 數(shù)組的方法 首先我們先打印一下Array.prototype看一下數(shù)組都有哪些方法 concat1.定義和用法:c...
    黃鶴你不是人閱讀 469評論 0 0
  • 一 一個佝僂著身子的矮胖男人,拿著一個金屬盆子,從后面通道走上來。男人一步一頓,看起來象腿腳不利索的樣子,手把盆子...
    大漠鈴兒響閱讀 457評論 0 0
  • 2017.7.21 之前有聽說過王陽明,但是從來沒想過要去看他的書或者了解他的生平。今天借著一起做到這個平臺,跟大...
    官洪芹閱讀 19,678評論 0 3

友情鏈接更多精彩內(nèi)容