javascript - Array.find+箭頭函數(shù)
問題描述
昨天看到一段代碼,是這樣的:
const pets = [ { type: ’Dog’, name: ’Max’}, { type: ’Cat’, name: ’Karl’}, { type: ’Dog’, name: ’Tommy’},]function findDog(name) { for(let i = 0; i<pets.length; ++i) { if(pets[i].type === ’Dog’ && pets[i].name === name) { return pets[i]; } }}
用短方法后:
pet = pets.find(pet => pet.type ===’Dog’ && pet.name === ’Tommy’);console.log(pet); // { type: ’Dog’, name: ’Tommy’ }
我查了查arr.find方法,定義是array.find(function(currentValue, index, arr),thisValue)
上面的代碼在pet=pets.find()內(nèi)又傳入pet,而沒有參數(shù),想知道這段代碼到底是如何實(shí)現(xiàn)的呢?請諸大神幫解惑
問題解答
回答1:pet = pets.find(function(pet) { return pet.type === ’Dog’ && pet.name === ’Tommy’;});
把箭頭函數(shù)轉(zhuǎn)換成ES5就是這樣。
find用于找出第一個符合條件的數(shù)組成員。它的參數(shù)是一個回調(diào)函數(shù),所有數(shù)組成員依次執(zhí)行該回調(diào)函數(shù),直到找出第一個返回值為true的成員,然后返回該成員。如果沒有符合條件的成員,則返回undefined。
這些API還是需要多查閱文檔,都是基礎(chǔ)知識不用轉(zhuǎn)彎的東西。
MDN文檔
es6 手冊
回答2:pets.find(pet => pet.type ===’Dog’ && pet.name === ’Tommy’);等效于
pets.find((pet) => { return pet.type ===’Dog’ && pet.name === ’Tommy’;});
箭頭函數(shù)只有一個參數(shù)的時候,小括號可以省略
相關(guān)文章:
1. 視頻文件不能播放,怎么辦?2. mysql - 把一個表中的數(shù)據(jù)count更新到另一個表里?3. 請教使用PDO連接MSSQL數(shù)據(jù)庫插入是亂碼問題?4. mysql 查詢身份證號字段值有效的數(shù)據(jù)5. visual-studio - Python OpenCV: 奇怪的自動補(bǔ)全問題6. mysql - 分庫分表、分區(qū)、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處7. node.js - nodejs開發(fā)中常用的連接mysql的庫8. python bottle跑起來以后,定時執(zhí)行的任務(wù)為什么每次都重復(fù)(多)執(zhí)行一次?9. python - 爬蟲模擬登錄后,爬取csdn后臺文章列表遇到的問題10. Python爬蟲如何爬取span和span中間的內(nèi)容并分別存入字典里?
