您好,登錄后才能下訂單哦!
本篇文章為大家展示了compose和pipe函數怎么在JavaScript中使用,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
1、能夠嵌入動態文本于HTML頁面。2、對瀏覽器事件做出響應。3、讀寫HTML元素。4、在數據被提交到服務器之前驗證數據。5、檢測訪客的瀏覽器信息。6、控制cookies,包括創建和修改等。7、基于Node.js技術進行服務器端編程。
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
數組的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.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函數跟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)
上述內容就是compose和pipe函數怎么在JavaScript中使用,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。