日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

詳解JS中的compose函數(shù)和pipe函數(shù)用法

瀏覽:202日期:2024-05-25 17:48:11
compose函數(shù)

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

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

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

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

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

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

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

Array.prototype.reduce

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

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

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

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

那這個compose方法要怎么實(shí)現(xiàn)呢,這里需要借助Array.prototype.reduceRight:

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

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

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

Redux的中間件就是用compose實(shí)現(xiàn)的,webpack中l(wèi)oader的加載順序也是從右往左,這是因?yàn)樗彩莄ompose實(shí)現(xiàn)的。

pipe函數(shù)

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

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

ES6寫法:

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

以上就是詳解JS中的compose函數(shù)和pipe函數(shù)用法的詳細(xì)內(nèi)容,更多關(guān)于JS的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
老司机精品视频网| 偷拍亚洲精品| 国产欧美69| 国产精品jk白丝蜜臀av小说| 国产精品久久久免费| 精品精品国产三级a∨在线| 精品欠久久久中文字幕加勒比| 国产黄色一区| 91嫩草亚洲精品| 亚洲韩日在线| 日韩影院在线观看| 欧美精品观看| а√在线中文在线新版| 亚洲午夜视频| 欧美日韩国产综合网| 在线观看视频免费一区二区三区| 91亚洲无吗| 波多野结衣久久精品| 亚洲欧美日韩高清在线| 欧美中文一区| 成人在线网站| 日本视频一区二区| 国产精品高颜值在线观看| 黄色av日韩| 奇米亚洲欧美| 91精品精品| 91综合久久爱com| av资源亚洲| 日韩中文字幕| 国产精品成人一区二区网站软件| 一区二区精品伦理...| 中文国产一区| 成人在线视频免费看| 国产模特精品视频久久久久| 国产日产高清欧美一区二区三区| 日韩天堂在线| 亚洲2区在线| 极品av在线| 蜜桃视频一区二区| 国产精品99一区二区三| 美女91精品| 国产一区二区三区不卡视频网站 | 免费久久精品视频| 久久av影视| 久久亚洲视频| 六月婷婷综合| 日本不卡高清视频| 四虎4545www国产精品| 日本视频一区二区| 国产综合色产| 免费看久久久| 免播放器亚洲一区| 91精品精品| 精品国产欧美| 少妇精品久久久一区二区| 日本不良网站在线观看| 日韩精品导航| 亚洲视频播放| 欧美亚洲在线日韩| 国产自产自拍视频在线观看| 日韩精品一区二区三区中文在线| 欧美久久精品一级c片| 四虎成人av| 国产极品嫩模在线观看91精品| 免费一区二区视频| 久久青草久久| 水蜜桃久久夜色精品一区| 欧美日韩91| 亚洲精品大全| 日韩亚洲在线| 999国产精品| 久久久久久夜| 国产精品99久久免费观看| 久久亚洲图片| 激情婷婷久久| 999久久久免费精品国产| 黑森林国产精品av| 高清av一区| 国精品产品一区| 国产精品啊啊啊| 日韩av午夜在线观看| 日本亚洲视频在线| 在线观看亚洲精品福利片| 午夜在线视频观看日韩17c| 日韩视频一区| 亚洲视频www| 在线国产一区二区| 免费精品国产的网站免费观看| 成人高清一区| 久久男人av| 美女在线视频一区| 麻豆精品在线| 国产一区二区精品福利地址| 国产欧美亚洲一区| 欧美国产专区| 91中文字幕精品永久在线| 国产一区二区三区四区| 成人影视亚洲图片在线| 免费看av不卡| 99成人在线视频| 午夜久久福利| 免费日韩av| 日韩欧美美女在线观看| 中文字幕一区二区av| 日韩精品a在线观看91| 欧美亚洲自偷自偷| 精品少妇av| 日本高清不卡一区二区三区视频| 亚洲精品.com| 一区久久精品| 亚洲欧洲美洲国产香蕉| 国产区精品区| 国产精品麻豆久久| 香蕉精品久久| 亚洲综合五月| 国产精区一区二区| 色婷婷色综合| 影音先锋国产精品| 亚洲3区在线| 国产欧美一区二区三区国产幕精品 | 午夜视频精品| 蜜臀久久99精品久久久画质超高清 | av高清一区| 视频一区二区三区入口| 亚洲欧洲美洲国产香蕉| 精品国产一级| 欧美不卡在线| 日本午夜精品一区二区三区电影 | 97精品国产福利一区二区三区| 欧美日韩视频免费观看| 亚洲综合日韩| 国产精品啊v在线| 99国产精品一区二区| 玖玖精品视频| 免费日韩一区二区三区| 国内精品福利| 91欧美极品| 日韩三区在线| 日韩在线成人| 日韩精品免费一区二区三区| 一本综合精品| 精品72久久久久中文字幕| 欧美精选一区二区三区| 国产欧美日韩精品高清二区综合区| 日韩专区在线视频| 久久亚洲精品伦理| 精品无人区麻豆乱码久久久 | 美女久久久久久| 欧美日韩高清| 国产精品极品在线观看| 欧美在线首页| 久久国产精品久久w女人spa| 视频一区国产视频| 亚洲人成高清| 国产欧洲在线| 亚洲精品看片| 亚洲精品国产嫩草在线观看 | 日韩精品一区第一页| 国际精品欧美精品| 蜜臀国产一区二区三区在线播放| 精品视频国内| 日韩中文字幕一区二区高清99| 伊人久久视频| 国产日韩免费| 久久大逼视频| 成人久久久久| 国产精品成人**免费视频| 亚洲主播在线| 在线人成日本视频| 亚洲精品第一| 国产精品精品国产一区二区| 日韩精品欧美成人高清一区二区| 伊人精品一区| 水蜜桃久久夜色精品一区| 日韩二区在线观看| 亚洲一区二区三区高清不卡| 日韩欧美一区二区三区免费看| 国产亚洲一区二区三区不卡| 三级亚洲高清视频| 欧美+日本+国产+在线a∨观看| 九九久久国产| 国产私拍福利精品视频二区| 蜜桃视频第一区免费观看| 日韩精品一区二区三区免费观影| 日韩中文av| 亚洲精品在线二区| 亚洲综合电影一区二区三区| 亚洲高清激情| 日韩中文字幕高清在线观看| 久久久久亚洲精品中文字幕| 欧美日韩网址| 亚洲精品动态| 热久久免费视频| 在线 亚洲欧美在线综合一区| 久久久精品午夜少妇| 成人福利av| 色婷婷狠狠五月综合天色拍| 美女一区网站| 色婷婷精品视频| 国产一区二区三区不卡视频网站 |