js-compose函數

compose函數

將函數扁平化處理

function fn1(x){
	return x + 1;
}
function fn2(x){
	return x + 10;
}
function fn3(x){
	return x*10;
}
function fn4(x){
	return x/10;
}
// fn1執行然後結果作爲fn2參數 一直執行到fn4;
fn4(fn3(fn2(fn1(5)))) // 16

但是這麼寫太麻煩了 所以可以簡化爲這樣 使用reduce 函數

function compose(...funs){
	return function proxy(...args){
		let len = funs.length;
		if(len===0){
			return args;
		}
		if(len === 1){
			return funs[0](...args);
		}
		return funs.reduce((x,y)=>{
			return typeof x === 'function' ? y(x(...args)) : y(x);
		})
	}
}
compose()(5); // [5]
compose(fn1,fn2,fn3,fn4)(5) // 16
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章