一次性讓大家搞懂JavaScript數(shù)組方法reduce、every、some
前言
在 JavaScript 開(kāi)發(fā)中,reduce
、every
和 some
是三個(gè)高頻使用的數(shù)組高階方法,但它們的用途和區(qū)別常常令人混淆。本文將用 原理剖析 + 場(chǎng)景對(duì)比 + 手寫(xiě)實(shí)現(xiàn) 幫你徹底理解它們,從此告別死記硬背!
一、reduce:數(shù)組的「熔爐」
1.1 核心特性
- 核心作用:將數(shù)組元素「熔煉」成一個(gè)值(任意類(lèi)型)
- 回調(diào)參數(shù):
(accumulator, current, index, array)
- 返回值:最終的累積結(jié)果(
accumulator
) - 初始值:可選的第二個(gè)參數(shù)
initialValue
(不傳時(shí)默認(rèn)用首元素)
1.2 使用場(chǎng)景
- 數(shù)學(xué)計(jì)算(求和/求積)
- 結(jié)構(gòu)轉(zhuǎn)換(數(shù)組→對(duì)象、扁平化數(shù)組)
- 數(shù)據(jù)聚合(統(tǒng)計(jì)詞頻)
1.3 示例代碼
// 求數(shù)組元素乘積 const nums = [2, 3, 4]; const product = nums.reduce((acc, num) => acc * num, 1); // 24 // 數(shù)組轉(zhuǎn)對(duì)象映射 const users = ['Alice', 'Bob']; const map = users.reduce((acc, user) => { acc[user] = true; return acc; }, {}); // { Alice: true, Bob: true }
1.4 原理實(shí)現(xiàn)
function myReduce(arr, callback, initialValue) { let acc = initialValue ?? arr[0]; let start = initialValue === undefined ? 1 : 0; for (let i = start; i < arr.length; i++) { acc = callback(acc, arr[i], i, arr); } return acc; }
二、every:數(shù)組的「質(zhì)檢員」
2.1 核心特性
- 核心作用:檢測(cè)是否 所有元素 都通過(guò)測(cè)試
- *回調(diào)參數(shù):(
element
,index
,array
) - 返回值:
true
(全部通過(guò)
) /false
(至少一個(gè)失?。?/li> - 短路特性:遇到第一個(gè)失敗項(xiàng)立即停止
2.2 使用場(chǎng)景
- 單全必填驗(yàn)證
- 權(quán)限全檢查
- 數(shù)據(jù)格式統(tǒng)一校驗(yàn)
2.3 示例代碼
// 是否全為偶數(shù) const nums = [2, 4, 6, 7]; const allEven = nums.every(num => num % 2 === 0); // false // 是否全為有效用戶 const users = [{age: 18}, {age: 20}]; const allValid = users.every(user => user.age >= 18); // true
2.4 原理實(shí)現(xiàn)
function myEvery(arr, callback) { for (let i = 0; i < arr.length; i++) { if (!callback(arr[i], i, arr)) return false; } return true; }
三、some:數(shù)組的「探測(cè)器」
3.1 核心特性
- 核心作用:檢測(cè)是否 至少有一個(gè)元素 通過(guò)測(cè)試
- 回調(diào)參數(shù):(
element
,index
,array
) - 返回值:
true
(至少一個(gè)通過(guò)) /false
(全部失?。?/li> - 短路特性:遇到第一個(gè)成功項(xiàng)立即停止
3.2 使用場(chǎng)景
- 搜索是否存在目標(biāo)元素
- 錯(cuò)誤快速檢測(cè)
- 功能可用性檢查
3.3 示例代碼
// 是否存在負(fù)數(shù) const nums = [3, -1, 5]; const hasNegative = nums.some(num => num < 0); // true // 是否有管理員用戶 const users = [{role: 'user'}, {role: 'admin'}]; const hasAdmin = users.some(user => user.role === 'admin'); // true
3.4 原理實(shí)現(xiàn)
function mySome(arr, callback) { for (let i = 0; i < arr.length; i++) { if (callback(arr[i], i, arr)) return true; } return false; }
四、橫向?qū)Ρ缺?/h2>
方法 | 返回值 | 短路特性 | 核心思想 | 類(lèi)比邏輯運(yùn)算符 |
---|---|---|---|---|
reduce | 任意類(lèi)型 | 無(wú) | 累積熔煉 | – |
every | 布爾值 | 有 | 全真 才為真 | && |
some | 布爾值 | 有 | 一真 即為真 | 或 |
五、記憶心法
reduce 聯(lián)想:
- 想象把數(shù)組元素扔進(jìn)熔爐,煉成一坨金屬錠(單一值)
every & some 對(duì)比:
every
→ 全員大會(huì)(必須所有人同意)some
→ 小組提案(只要一人支持即可)- 互斥關(guān)系:
arr.every(cond)
===!arr.some(!cond)
六、實(shí)戰(zhàn)訓(xùn)練
1. 用 reduce 實(shí)現(xiàn)數(shù)組去重
const arr = [1, 2, 2, 3]; const unique = arr.reduce((acc, num) => acc.includes(num) ? acc : [...acc, num], [] );
2. 用 every 檢測(cè)全大寫(xiě)字符串
const words = ['HELLO', 'WORLD']; const isAllUpper = words.every(word => word === word.toUpperCase() ); // true
3. 用 some 檢查素?cái)?shù)存在性
const nums = [4, 6, 8, 11]; const hasPrime = nums.some(num => { for (let i = 2; i <= Math.sqrt(num); i++) { if (num % i === 0) return false; } return num > 1; }); // true(11是素?cái)?shù))
總結(jié)
理解這三個(gè)方法的關(guān)鍵在于抓住它們的 數(shù)據(jù)流向 和 設(shè)計(jì)目的:
reduce
關(guān)注 累積過(guò)程,適合數(shù)據(jù)聚合every/some
關(guān)注 布爾決策,適合條件驗(yàn)證
下次忘記用法時(shí),只需問(wèn)自己:
- 我需要把數(shù)組變成另一個(gè)值嗎?→ reduce
- 我要檢查所有元素嗎?→ every
- 我要檢查至少一個(gè)元素嗎?→ some
到此這篇關(guān)于JavaScript數(shù)組方法reduce、every、some的文章就介紹到這了,更多相關(guān)JS數(shù)組方法reduce、every、some內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS中Iframe之間傳值及子頁(yè)面與父頁(yè)面應(yīng)用
用iframe做系統(tǒng)框架,相信很多朋友都有這樣的經(jīng)歷吧,接下來(lái)將為你詳細(xì)介紹下JS中Iframe之間傳值應(yīng)用,感興趣的你可以參考下哈,希望可以幫助到你2013-03-03JavaScript中利用Array filter() 方法壓縮稀疏數(shù)組
Array filter() 方法會(huì)跳過(guò)稀疏數(shù)組中缺少的元素,它的返回?cái)?shù)組總是稠密的。這篇文章給大家介紹了JavaScript中利用Array filter() 方法壓縮稀疏數(shù)組的相關(guān)知識(shí),需要的朋友參考下2018-02-02js簡(jiǎn)單實(shí)現(xiàn)點(diǎn)擊左右運(yùn)動(dòng)的方法
這篇文章主要介紹了js簡(jiǎn)單實(shí)現(xiàn)點(diǎn)擊左右運(yùn)動(dòng)的方法,實(shí)例分析了javascript實(shí)現(xiàn)左右運(yùn)動(dòng)的相關(guān)要點(diǎn)與技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04JavaScript文本特效實(shí)例小結(jié)【3個(gè)示例】
這篇文章主要介紹了JavaScript文本特效,結(jié)合3個(gè)實(shí)例分析了javascript基于定時(shí)器的文字動(dòng)態(tài)操作特效相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-12-12淺談JS正則表達(dá)式的RegExp對(duì)象和括號(hào)的使用
下面小編就為大家?guī)?lái)一篇淺談JS正則表達(dá)式的RegExp對(duì)象和括號(hào)的使用。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07javascript實(shí)現(xiàn)點(diǎn)擊按鈕讓DIV層彈性移動(dòng)的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)點(diǎn)擊按鈕讓DIV層彈性移動(dòng)的方法,實(shí)例分析了javascript操作div層的操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02詳解小程序設(shè)置緩存并且不覆蓋原有數(shù)據(jù)
這篇文章主要介紹了小程序設(shè)置緩存并且不覆蓋原有數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04