溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

compose和pipe函數(shù)怎么在JavaScript中使用

發(fā)布時(shí)間:2021-04-27 15:46:51 來源:億速云 閱讀:178 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章為大家展示了compose和pipe函數(shù)怎么在JavaScript中使用,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

JavaScript的作用是什么

1、能夠嵌入動(dòng)態(tài)文本于HTML頁面。2、對(duì)瀏覽器事件做出響應(yīng)。3、讀寫HTML元素。4、在數(shù)據(jù)被提交到服務(wù)器之前驗(yàn)證數(shù)據(jù)。5、檢測(cè)訪客的瀏覽器信息。6、控制cookies,包括創(chuàng)建和修改等。7、基于Node.js技術(shù)進(jìn)行服務(wù)器端編程。

compose函數(shù)

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

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

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

const add = x => x + 10;
const multiply = x => x * 10;

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

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

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

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

Array.prototype.reduce

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

const arr = [[1, 2], [3, 4], [5, 6]];
// prevRes的初始值是傳入的[],以后會(huì)是每次迭代計(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會(huì)從左往右進(jìn)行迭代,如果需要從右往左迭代,用Array.prototype.reduceRight就好了

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

console.log(flatArr); // [5, 6, 3, 4, 1, 2]

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

const compose = function(){
  // 將接收的參數(shù)存到一個(gè)數(shù)組, args == [multiply, add]
  const args = [].slice.apply(arguments);
  return function(x) {
    return args.reduceRight((res, cb) => cb(res), x);
  }
}

// 我們來驗(yàn)證下這個(gè)方法
let calculate = compose(multiply, add);
let res = calculate(10);
console.log(res);    // 結(jié)果還是200

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

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)

上述內(nèi)容就是compose和pipe函數(shù)怎么在JavaScript中使用,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI