欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解析JavaScript數(shù)組方法reduce

 更新時間:2016年12月12日 14:41:32   作者:unclekeith  
本文主要介紹了JavaScript數(shù)組方法reduce的概述、語法、參數(shù)、工作原理等,由淺入深,便于理解。需要的朋友可以看下

Array.prototype.reduce()

概述

reduce()方法是數(shù)組的一個實例方法(共有方法),可以被數(shù)組的實例對象調(diào)用。reduce() 方法接收一個函數(shù)作為累加器(accumulator),數(shù)組中的每個值(從左到右)開始縮減,最終為一個值。

語法

arr.reduce(callback[, initialValue]) {}

參數(shù)

回調(diào)函數(shù)中可以傳遞四個參數(shù)。

previousValue:上一次調(diào)用回調(diào)函數(shù)返回的值,或者是提供的初始值(initialValue)

currentValue:數(shù)組中當(dāng)前被處理的元素

currentIndex:當(dāng)前被處理元素在數(shù)組中的索引, 即currentValue的索引.如果有initialValue初始值, 從0開始.如果沒有從1開始

array:調(diào)用 reduce 的數(shù)組

initialValue:可選參數(shù), 作為第一次調(diào)用 callback 的第一個參數(shù)

返回值

reduce()返回值是最后一次調(diào)用回調(diào)函數(shù)返回的結(jié)果

描述

reduce 為數(shù)組中的每一個元素依次執(zhí)行回調(diào)函數(shù),不包括數(shù)組中被刪除或從未被賦值的元素,接受四個參數(shù):

  1. previousValu 上一次值
  2. currentValue 當(dāng)前值
  3. currentIndex 當(dāng)前值的索引
  4. array 數(shù)組

回調(diào)函數(shù)第一次執(zhí)行時,previousValue 和 currentValue可能是兩個不同值其中的一個,如果reduce有initialValue參數(shù),那么 previousValue 等于 initialValue ,并且currentValue 等于數(shù)組中的第一個值;如果reduce沒有 initialValue 參數(shù),那么previousValue 等于數(shù)組中的第一個值,currentValue等于數(shù)組中的第二個值。

注意: 如果沒有initialValue參數(shù), reduce從index為1開始執(zhí)行回調(diào)函數(shù), 跳過第一個index。 如果有initialValue參數(shù), reduce 將從index為 0 開始執(zhí)行回調(diào)

如果數(shù)組是空的并且沒有initialValue參數(shù), 將會拋出TypeError錯誤. 如果數(shù)組只有一個元素并且沒有初始值initialValue, 或者有initialValue但數(shù)組是空的, 這個唯一的值直接被返回而不會調(diào)用回調(diào)函數(shù)。

通常來說提供一個initialValue初始值更安全一點, 因為沒有的話會出現(xiàn)如下輸出結(jié)果。

//沒有提供initialValue
function foo(){
 return [1,2,3,4,5].reduce((x, y) => x + y); //15
};
console.log(foo.call(this));
function foo(){
 return [].reduce((x, y) => x + y); //TypeError
};
console.log(foo.call(this));
//提供initialValue
function foo(){
 return [].reduce((x, y) => x + y, 0); //0
};
console.log(foo.call(this));

reduce()是如何工作的

[0, 1, 2, 3, 4].reduce((previousValue, currentValue, index, array) => previousValue + currentValue);

回調(diào)被執(zhí)行四次,每次的參數(shù)和返回值如下表:

reduce 的返回值是回調(diào)函數(shù)最后一次被調(diào)用的返回值(10)。

如果把初始值作為第二個參數(shù)傳入 reduce,結(jié)果如下,結(jié)果如下:

[0, 1, 2, 3, 4].reduce((previousValue, currentValue, index, array) => previousValue + currentValue, 10);

最后一次函數(shù)調(diào)用的返回值 (20) 作為reduce函數(shù)的結(jié)果被返回

注意:添加了initialValue參數(shù)會多調(diào)用一次回調(diào)函數(shù)

例題

將數(shù)組所有項相加

let sum = [0, 1, 2, 3, 4].reduce((x, y) => x + y, 0); 
// 10

扁平化一個二維數(shù)組

let arr = [[1, 2], [3, 4], [5, 6]].reduce((x, y) => x.concat(y), []);
// [1, 2, 3, 4, 5, 6]

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關(guān)文章

  • JavaScript實現(xiàn)鼠標(biāo)拖拽效果

    JavaScript實現(xiàn)鼠標(biāo)拖拽效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)鼠標(biāo)拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • JavaScript常用工具方法封裝

    JavaScript常用工具方法封裝

    今天小編就為大家分享一篇關(guān)于JavaScript常用工具方法封裝,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • 微信小程序仿今日頭條導(dǎo)航欄滾動解析

    微信小程序仿今日頭條導(dǎo)航欄滾動解析

    這篇文章主要介紹了微信小程序仿今日頭條導(dǎo)航欄滾動解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • 解決ie11 SCRIPT5011:不能執(zhí)行已釋放Script的代碼問題

    解決ie11 SCRIPT5011:不能執(zhí)行已釋放Script的代碼問題

    這篇文章主要介紹了ie11 SCRIPT5011:不能執(zhí)行已釋放Script的代碼 ,需要的朋友可以參考下
    2019-05-05
  • 微信小程序?qū)⒆址啥S碼圖片的操作方法

    微信小程序?qū)⒆址啥S碼圖片的操作方法

    這篇文章主要介紹了微信小程序?qū)⒆址啥S碼圖片的操作方法,需要的朋友可以參考下
    2018-07-07
  • webpack自動打包功能實現(xiàn)

    webpack自動打包功能實現(xiàn)

    webpack是前端項目構(gòu)建工具打包工具,本文通過實例代碼給大家介紹webpack自動打包功能實現(xiàn),感興趣的朋友跟隨小編一起看看吧
    2023-02-02
  • 微信小程序獲取用戶信息的兩種方法wx.getUserInfo與open-data實例分析

    微信小程序獲取用戶信息的兩種方法wx.getUserInfo與open-data實例分析

    這篇文章主要介紹了微信小程序獲取用戶信息的兩種方法wx.getUserInfo與open-data,結(jié)合實例形式分析了wx.getUserInfo與open-data獲取用戶信息的相關(guān)操作技巧與使用注意事項,需要的朋友可以參考下
    2019-05-05
  • ES6的新特性概覽

    ES6的新特性概覽

    Nick Justice是GitHub開發(fā)者計劃的一員。早在ES6語言標(biāo)準(zhǔn)發(fā)布之前,他就借助像Babel這樣的轉(zhuǎn)譯器以及最新版本的瀏覽器在自己的項目中使用ES6特性。他認(rèn)為,ES6的新特性將極大地改變JavaScript的編寫方式
    2016-03-03
  • Webpack中publicPath路徑問題詳解

    Webpack中publicPath路徑問題詳解

    這篇文章主要介紹了Webpack中publicPath路徑問題詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • JavaScript 判斷一個對象{}是否為空對象的簡單方法

    JavaScript 判斷一個對象{}是否為空對象的簡單方法

    下面小編就為大家?guī)硪黄狫avaScript 判斷一個對象{}是否為空對象的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10

最新評論