电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

JS數(shù)組Reduce方法功能與用法實例詳解

瀏覽:103日期:2024-05-10 18:02:58

本文實例講述了JS數(shù)組Reduce方法功能與用法。分享給大家供大家參考,具體如下:

概述

一直以來都在函數(shù)式編程的大門之外徘徊,要入門的話首先得熟悉各種高階函數(shù),數(shù)組的reduce方法就是其中之一。

reduce方法將會對數(shù)組元素從左到右依次執(zhí)行reducer函數(shù),然后返回一個累計的值。舉個形象的例子:你要組裝一臺電腦,買了主板、CPU、顯卡、內(nèi)存、硬盤、電源...這些零件是組裝電腦的必要條件。

裝的過程可以簡單概括為拆掉每個零件的包裝,再裝到一起。類比一下reduce函數(shù)就可以明白了,那些零件就相當于要執(zhí)行reduce方法的數(shù)組,對每個零件執(zhí)行拆除包裝的加工程序,就是對數(shù)組的每個元素執(zhí)行reducer函數(shù),把這些零件裝到一起,就相當于reduce方法的任務(wù),最終組裝好的電腦相當于reduce方法的返回值。

reduce方法接收兩個參數(shù),第一個參數(shù)是回調(diào)函數(shù)reducer,第二個參數(shù)是初始值。reducer函數(shù)接收四個參數(shù):

Accumulator:MDN上解釋為累計器,但我覺得不恰當,按我的理解它應(yīng)該是截至當前元素,之前所有的數(shù)組元素被reducer函數(shù)處理累計的結(jié)果 Current:當前被執(zhí)行的數(shù)組元素 CurrentIndex: 當前被執(zhí)行的數(shù)組元素索引 SourceArray:原數(shù)組,也就是調(diào)用reduce方法的數(shù)組

如果傳入第二個參數(shù),reduce方法會在這個參數(shù)的基礎(chǔ)上開始累計執(zhí)行。

概念講了那么多,那reduce它的執(zhí)行機制是怎樣的呢?別著急,從用法入手一點一點分析。

來個最好理解的例子:數(shù)組求和

const arr = [1, 2, 3, 4] const accumulator = (total, current, currentIndex, arr) => { console.log(total, current, currentIndex, arr); return total + current } console.log(arr.reduce(accumulator))

執(zhí)行結(jié)果如下:

JS數(shù)組Reduce方法功能與用法實例詳解

很明確,最終的結(jié)果就是把所有數(shù)組的元素都加起來。值得注意的是,它將數(shù)組的第一個元素作為累加的初始值,然后再依次對后邊的元素執(zhí)行reducer函數(shù)。

總共執(zhí)行了三次,得出最終結(jié)果。那如果傳入初始值,是怎樣的執(zhí)行順序?

console.log(arr.reduce(accumulator, 3))

結(jié)果如下:

JS數(shù)組Reduce方法功能與用法實例詳解

這次是以傳入的初始值作為累加的起點,然后依次對數(shù)組的元素執(zhí)行reducer。

假設(shè)對沒有初始值的空數(shù)組調(diào)用reduce方法,則會報錯:

Uncaught TypeError: Reduce of empty array with no initial value

一些用法

講了一些概念,但使用場景更重要,下面來看一下reduce方法都會有哪些用途。

compose函數(shù)

compose是函數(shù)式編程的一種形式,用于將多個函數(shù)合并,上一個函數(shù)的返回值作為當前函數(shù)的入?yún)ⅲ斍昂瘮?shù)的返回值再作為下一個函數(shù)的入?yún)ⅲ@樣的效果有點類似于koa中間件的洋蔥模型。

[a, b, c, d] => a(b(c(d())))

實際上和累加差不多,只不過把累加操作變成了入?yún)?zhí)行,相加的結(jié)果變成了執(zhí)行的返回值。redux的applyMiddleware內(nèi)就使用了compose,目的是保證最終的dispatch是被所有中間件處理后的結(jié)果。

下面來以applyMiddleware中的compose為例,先看用法:

const result = compose(a, b, c)(params)

執(zhí)行情況是這樣:

(params) => a(b(c(params)))

返回的是一個函數(shù),將params作為該函數(shù)的入?yún)ⅲ挥覀?cè)第一個函數(shù)執(zhí)行,執(zhí)行順序是從右到左執(zhí)行,其余的函數(shù)的參數(shù)都是上一個函數(shù)的返回值。

看一下實現(xiàn):

function compose(...funcs) { // funcs是compose要組合的那些函數(shù),arg是componse返回的函數(shù)的參數(shù) if (funcs.length === 0) { // 如果沒有傳入函數(shù),那么直接返回一個函數(shù),函數(shù)的返回值就是傳進來的參數(shù) return arg => arg } if (funcs.length === 1) { // 如果只傳入了一個函數(shù),直接返回這個函數(shù) return funcs[0] } return funcs.reduce((all, current) => { return (...args) => { return all(current(...args)) } })}扁平化數(shù)組

const array = [[0, 1], [2, 3], [4, 5]]const flatten = arr => { return arr.reduce((a, b) => { return a.concat(b) }, [])}console.log(flatten(array)); // [0, 1, 2, 3, 4, 5]

來看一下執(zhí)行過程,

第一次執(zhí)行,初始值傳入[],走到reduce的回調(diào)里,參數(shù)a就這個[],參數(shù)b是數(shù)組第一項[0, 1],回調(diào)內(nèi)[].cancat([0, 1]) 第二次執(zhí)行,reduce的回調(diào)參數(shù)a是上一次回調(diào)執(zhí)行的結(jié)果[0, 1],本次繼續(xù)用它來concat數(shù)組的第二項[2, 3],得到結(jié)果[0, 1, 2, 3]作為下一次回調(diào)執(zhí)行的參數(shù)a繼續(xù)執(zhí)行下去 ...以此類推

那么假設(shè)數(shù)組是這樣呢?[[0, [111, 222], 1], [2, [333, [444, 555]], 3], [4, 5]],其實加個遞歸調(diào)用就可以

const array = [[0, [111, 222], 1], [2, [333, [444, 555]], 3], [4, 5]]const flatten = arr => { return arr.reduce((a, b) => { if (b instanceof Array) { return a.concat(flatten(b)) } return a.concat(b) }, [])}console.log(flatten(array)); // [0, 111, 222, 1, 2, 333, 444, 555, 3, 4, 5]統(tǒng)計字符串中每個字符出現(xiàn)的次數(shù)

每次回調(diào)執(zhí)行的時候,都會往對象中加一個key為字符串,value為出現(xiàn)次數(shù)的鍵值,若已經(jīng)存儲過字符串,那么它的value加1。

const str = ’adefrfdnnfhdueassjfkdiskcddfjds’const arr = str.split(’’)const strObj = arr.reduce((all, current) => { if (current in all) { all[current]++ } else { all[current] = 1 } return all}, {})console.log(strObj)// {'a':2,'d':7,'e':2,'f':5,'r':1,'n':2,'h':1,'u':1,'s':4,'j':2,'k':2,'i':1,'c':1}數(shù)組去重

const arr = [’1’, ’a’, ’c’, ’d’, ’a’, ’c’, ’1’]const afterUnique = arr.reduce((all, current) => { if (!all.includes(current)) { all.push(current) } return all}, [])console.log(afterUnique); // ['1', 'a', 'c', 'd']按照順序調(diào)用promise

這種方式實際上處理的是promise的value,將上一個promise的value作為下一個promise的value進行處理。

const prom1 = a => { return new Promise((resolve => { resolve(a) }))}const prom2 = a => { return new Promise((resolve => { resolve(a * 2) }))}const prom3 = a => { return new Promise((resolve => { resolve(a * 3) }))}const arr = [prom1, prom2, prom3]const result = arr.reduce((all, current) => { return all.then(current)}, Promise.resolve(10))result.then(res => { console.log(res);})實現(xiàn)

通過上面的用法,可以總結(jié)出來reduce的特點:

接收兩個參數(shù),第一個為函數(shù),函數(shù)內(nèi)會接收四個參數(shù):Accumulator Current CurrentIndex SourceArray,第二個參數(shù)為初始值。 返回值為一個所有Accumulator累計執(zhí)行的結(jié)果

Array.prototype.myReduce = function(fn, base) { if (this.length === 0 && !base) { throw new Error(’Reduce of empty array with no initial value’) } for (let i = 0; i < this.length; i++) { if (!base) { base = fn(this[i], this[i + 1], i, this) i++ } else { base = fn(base, this[i], i, this) } } return base }

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

標簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 便携式XPDM露点仪-在线式防爆露点仪-增强型烟气分析仪-约克仪器 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 上海皓越真空设备有限公司官网-真空炉-真空热压烧结炉-sps放电等离子烧结炉 | 杭州厂房降温,车间降温设备,车间通风降温,厂房降温方案,杭州嘉友实业爽风品牌 | QQ房产导航-免费收录优秀房地产网站_房地产信息网 | 杭州画室_十大画室_白墙画室_杭州美术培训_国美附中培训_附中考前培训_升学率高的画室_美术中考集训美术高考集训基地 | 12cr1mov无缝钢管切割-15crmog无缝钢管切割-40cr无缝钢管切割-42crmo无缝钢管切割-Q345B无缝钢管切割-45#无缝钢管切割 - 聊城宽达钢管有限公司 | 污水/卧式/潜水/钻井/矿用/大型/小型/泥浆泵,价格,参数,型号,厂家 - 安平县鼎千泵业制造厂 | 东莞注册公司-代办营业执照-东莞公司注册代理记账-极刻财税 | 艾默生变频器,艾默生ct,变频器,ct驱动器,广州艾默生变频器,供水专用变频器,风机变频器,电梯变频器,艾默生变频器代理-广州市盟雄贸易有限公司官方网站-艾默生变频器应用解决方案服务商 | 国产离子色谱仪,红外分光测油仪,自动烟尘烟气测试仪-青岛埃仑通用科技有限公司 | 全自动烧卖机厂家_饺子机_烧麦机价格_小笼汤包机_宁波江北阜欣食品机械有限公司 | 涡街流量计_LUGB智能管道式高温防爆蒸汽温压补偿计量表-江苏凯铭仪表有限公司 | 搅拌磨|搅拌球磨机|循环磨|循环球磨机-无锡市少宏粉体科技有限公司 | 粘度计,数显粘度计,指针旋转粘度计 | Eiafans.com_环评爱好者 环评网|环评论坛|环评报告公示网|竣工环保验收公示网|环保验收报告公示网|环保自主验收公示|环评公示网|环保公示网|注册环评工程师|环境影响评价|环评师|规划环评|环评报告|环评考试网|环评论坛 - Powered by Discuz! | 气动|电动调节阀|球阀|蝶阀-自力式调节阀-上海渠工阀门管道工程有限公司 | 臻知网大型互动问答社区-你的问题将在这里得到解答!-无锡据风网络科技有限公司 | 北京亦庄厂房出租_经开区产业园招商信息平台 | 机器视觉检测系统-视觉检测系统-机器视觉系统-ccd检测系统-视觉控制器-视控一体机 -海克易邦 | 政府回应:200块在义乌小巷能买到爱情吗?——揭秘打工族省钱约会的生存智慧 | 皮带式输送机械|链板式输送机|不锈钢输送机|网带输送机械设备——青岛鸿儒机械有限公司 | 废旧物资回收公司_广州废旧设备回收_报废设备物资回收-益美工厂设备回收公司 | 镀锌方管,无缝方管,伸缩套管,方矩管_山东重鑫致胜金属制品有限公司 | 压砖机_电动螺旋压力机_粉末成型压力机_郑州华隆机械tel_0371-60121717 | SMN-1/SMN-A ABB抽屉开关柜触头夹紧力检测仪-SMN-B/SMN-C-上海徐吉 | 汕头市盛大文化传播有限公司,www.11400.cc| 空调风机,低噪声离心式通风机,不锈钢防爆风机,前倾皮带传动风机,后倾空调风机-山东捷风风机有限公司 | 政府园区专业委托招商平台_助力企业选址项目快速落地_东方龙商务集团 | 交流伺服电机|直流伺服|伺服驱动器|伺服电机-深圳市华科星电气有限公司 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 长春网站建设,五合一网站设计制作,免费优化推广-长春网站建设 | 维泰克Veertek-锂电池微短路检测_锂电池腐蚀检测_锂电池漏液检测 | 色油机-色母机-失重|称重式混料机-称重机-米重机-拌料机-[东莞同锐机械]精密计量科技制造商 | 天津散热器_天津暖气片_天津安尼威尔散热器制造有限公司 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 非小号行情 - 专业的区块链、数字藏品行情APP、金色财经官网 | 千淘酒店差旅平台-中国第一家针对TMC行业的酒店资源供应平台 | 游动电流仪-流通式浊度分析仪-杰普仪器(上海)有限公司 | 金属检测机_金属分离器_检针验针机_食品药品金属检探测仪器-广东善安科技 | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 |