亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

Array.prototype.reduce()

概述

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

語(yǔ)法

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

參數(shù)

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

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

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

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

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

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

返回值

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

描述

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

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

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

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

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

通常來(lái)說(shuō)提供一個(gè)initialValue初始值更安全一點(diǎn), 因?yàn)闆](méi)有的話會(huì)出現(xiàn)如下輸出結(jié)果。

//沒(méi)有提供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)。

如果把初始值作為第二個(gè)參數(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ù)會(huì)多調(diào)用一次回調(diào)函數(shù)

例題

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

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

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

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

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

相關(guān)文章

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

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

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

    JavaScript常用工具方法封裝

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

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

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

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

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

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

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

    webpack自動(dòng)打包功能實(shí)現(xiàn)

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

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

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

    ES6的新特性概覽

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

    Webpack中publicPath路徑問(wèn)題詳解

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

    JavaScript 判斷一個(gè)對(duì)象{}是否為空對(duì)象的簡(jiǎn)單方法

    下面小編就為大家?guī)?lái)一篇JavaScript 判斷一個(gè)對(duì)象{}是否為空對(duì)象的簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10

最新評(píng)論