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

您的位置:首頁技術文章
文章詳情頁

詳解JS中的compose函數和pipe函數用法

瀏覽:128日期:2024-05-25 17:48:11
compose函數

compose函數可以將需要嵌套執行的函數平鋪,嵌套執行就是一個函數的返回值將作為另一個函數的參數。我們考慮一個簡單的需求:這個需求很簡單,直接一個計算函數就行:

const calculate = x => (x + 10) * 10;let res = calculate(10);console.log(res); // 200

但是根據我們之前講的函數式編程,我們可以將復雜的幾個步驟拆成幾個簡單的可復用的簡單步驟,于是我們拆出了一個加法函數和一個乘法函數:

const add = x => x + 10;const multiply = x => x * 10;// 我們的計算改為兩個函數的嵌套計算,add函數的返回值作為multiply函數的參數let res = multiply(add(10));console.log(res); // 結果還是200

上面的計算方法就是函數的嵌套執行,而我們compose的作用就是將嵌套執行的方法作為參數平鋪,嵌套執行的時候,里面的方法也就是右邊的方法最開始執行,然后往左邊返回,我們的compose方法也是從右邊的參數開始執行,所以我們的目標就很明確了,我們需要一個像這樣的compose方法:

// 參數從右往左執行,所以multiply在前,add在后let res = compose(multiply, add)(10);

在講這個之前我們先來看一個需要用到的函數Array.prototype.reduce

Array.prototype.reduce

數組的reduce方法可以實現一個累加效果,它接收兩個參數,第一個是一個累加器方法,第二個是初始化值。累加器接收四個參數,第一個是上次的計算值,第二個是數組的當前值,主要用的就是這兩個參數,后面兩個參數不常用,他們是當前index和當前迭代的數組:

const arr = [[1, 2], [3, 4], [5, 6]];// prevRes的初始值是傳入的[],以后會是每次迭代計算后的值const flatArr = arr.reduce((prevRes, item) => prevRes.concat(item), []);console.log(flatArr); // [1, 2, 3, 4, 5, 6]Array.prototype.reduceRight

Array.prototype.reduce會從左往右進行迭代,如果需要從右往左迭代,用Array.prototype.reduceRight就好了

const arr = [[1, 2], [3, 4], [5, 6]];// prevRes的初始值是傳入的[],以后會是每次迭代計算后的值const flatArr = arr.reduceRight((prevRes, item) => prevRes.concat(item), []);console.log(flatArr); // [5, 6, 3, 4, 1, 2]

那這個compose方法要怎么實現呢,這里需要借助Array.prototype.reduceRight:

const compose = function(){ // 將接收的參數存到一個數組, args == [multiply, add] const args = [].slice.apply(arguments); return function(x) { return args.reduceRight((res, cb) => cb(res), x); }}// 我們來驗證下這個方法let calculate = compose(multiply, add);let res = calculate(10);console.log(res); // 結果還是200

上面的compose函數使用ES6的話會更加簡潔:

const compose = (...args) => x => args.reduceRight((res, cb) => cb(res), x);

Redux的中間件就是用compose實現的,webpack中loader的加載順序也是從右往左,這是因為他也是compose實現的。

pipe函數

pipe函數跟compose函數的左右是一樣的,也是將參數平鋪,只不過他的順序是從左往右。我們來實現下,只需要將reduceRight改成reduce就行了:

const pipe = function(){ const args = [].slice.apply(arguments); return function(x) { return args.reduce((res, cb) => cb(res), x); }}// 參數順序改為從左往右let calculate = pipe(add, multiply);let res = calculate(10);console.log(res); // 結果還是200

ES6寫法:

const pipe = (...args) => x => args.reduce((res, cb) => cb(res), x)

以上就是詳解JS中的compose函數和pipe函數用法的詳細內容,更多關于JS的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 铸铁平台,大理石平台专业生产厂家_河北-北重机械 | 刺绳_刀片刺网_刺丝滚笼_不锈钢刺绳生产厂家_安平县浩荣金属丝网制品有限公司-安平县浩荣金属丝网制品有限公司 | 广州企亚 - 数码直喷、白墨印花、源头厂家、透气无手感方案服务商! | 奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌 | 成都LED显示屏丨室内户外全彩led屏厂家方案报价_四川诺显科技 | 蒸汽吸附分析仪-进口水分活度仪|康宝百科 | 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | 济南网站建设|济南建网站|济南网站建设公司【济南腾飞网络】【荐】 | 自动化改造_智虎机器人_灌装机_贴标机-上海圣起包装机械 | 进口消泡剂-道康宁消泡剂-陶氏消泡剂-大洋消泡剂 | 电子元器件呆滞料_元器件临期库存清仓尾料_尾料优选现货采购处理交易商城 | 北京浩云律师事务所-法律顾问_企业法务_律师顾问_公司顾问 | 酵素生产厂家_酵素OEM_酵素加盟_酵素ODM_酵素原料厂家_厦门益力康 | 东莞注册公司-代办营业执照-东莞公司注册代理记账-极刻财税 | 博莱特空压机|博莱特-阿特拉斯独资空压机品牌核心代理商 | 西安展台设计搭建_西安活动策划公司_西安会议会场布置_西安展厅设计西安旭阳展览展示 | 无缝钢管-聊城无缝钢管-小口径无缝钢管-大口径无缝钢管 - 聊城宽达钢管有限公司 | 蒸压釜-陶粒板隔墙板蒸压釜-山东鑫泰鑫智能装备有限公司 | 水质传感器_水质监测站_雨量监测站_水文监测站-山东水境传感科技有限公司 | 123悬赏网_发布悬赏任务_广告任务平台| SRRC认证_电磁兼容_EMC测试整改_FCC认证_SDOC认证-深圳市环测威检测技术有限公司 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | 西宁装修_西宁装修公司-西宁业之峰装饰-青海业之峰墅级装饰设计公司【官网】 | 空调风机,低噪声离心式通风机,不锈钢防爆风机,前倾皮带传动风机,后倾空调风机-山东捷风风机有限公司 | 四川职高信息网-初高中、大专、职业技术学校招生信息网 | 游戏版号转让_游戏资质出售_游戏公司转让-【八九买卖网】 | 压缩空气检测_气体_水质找上海京工-服务专业、价格合理 | 岛津二手液相色谱仪,岛津10A液相,安捷伦二手液相,安捷伦1100液相-杭州森尼欧科学仪器有限公司 | 精密模具加工制造 - 富东懿| 「银杏树」银杏树行情价格_银杏树种植_山东程锦园林 | 二手注塑机回收_旧注塑机回收_二手注塑机买卖 - 大鑫二手注塑机 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 膜片万向弹性联轴器-冲压铸造模具「沧州昌运模具」 | 卓能JOINTLEAN端子连接器厂家-专业提供PCB接线端子|轨道式端子|重载连接器|欧式连接器等电气连接产品和服务 | 生鲜配送系统-蔬菜食材配送管理系统-连锁餐饮订货配送软件-挪挪生鲜供应链管理软件 | 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 标策网-专注公司商业知识服务、助力企业发展 | 电动百叶窗,开窗器,电动遮阳百叶,电动开窗机生产厂家-徐州鑫友工控科技发展有限公司 | 精密机械零件加工_CNC加工_精密加工_数控车床加工_精密机械加工_机械零部件加工厂 | 热风机_工业热风机生产厂家上海冠顶公司提供专业热风机图片价格实惠 | 齿轮减速机_齿轮减速电机-VEMT蜗轮蜗杆减速机马达生产厂家瓦玛特传动瑞环机电 | 新疆散热器,新疆暖气片,新疆电锅炉,光耀暖通公司 |