国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:97日期: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
相關文章:
主站蜘蛛池模板: 免费播放aa在线视频成人 | 香蕉超级碰碰碰97视频在线观看 | 免费观看亚洲视频 | 日本乱子伦xxxx | 91精品乱码一区二区三区 | 特大一级aaaaa毛片 | 精品久久久久久国产 | 秘书高跟黑色丝袜国产91在线 | 国产成人亚洲综合91精品555 | 一区二区三区在线 | 网站 | 精品国产成人a在线观看 | 亚洲综合在线视频 | 国产做国产爱免费视频 | 久久国产精品最新一区 | 大片在线播放日本一级毛片 | 精品视频在线一区 | 波多野结衣中文一区二区免费 | 国产精品亲子乱子伦xxxx裸 | 91精品综合久久久久m3u8 | 久久久精品成人免费看 | 99福利资源久久福利资源 | 亚洲精品天堂自在久久77 | 久草在线新视频 | 伊人久久影视 | 欧美国产大片 | vr18成人资源 | 97视频久久 | 久久视屏这里只有精品6国产 | 久久99精品久久久久久久野外 | 精品国产综合成人亚洲区 | 91久久国产口精品久久久久 | 午夜成年女人毛片免费观看 | 欧美国产精品 | 免费观看a毛片一区二区不卡 | 99久久精品免费国产一区二区三区 | 欧美在线综合视频 | 日本高清免费视频色www | 欧美午夜免费毛片a级 | 国产aaa毛片 | 国产精品成人一区二区 | 波多野结衣在线视频观看 |