這篇文章帶給大家的內容是關於JavaScript實作柯里化(curry)函數的想法和原始碼,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
實作效果
const curry_fn = curry(fn); fn(1, 2, 3) == curry_fn(1)(2)(3);
#透過閉包的方式儲存傳入參數
透過函數的length屬性取得參數個數
當參數個數不夠時直接傳回方法
儲存的參數數等於原函數參數個數時執行原函數
如果使用ES6參數預設值,length將不等於實際參數個數
參數由arguments取得,ES6直接使用rest參數實作
function curry(fn) { var length = fn.length; //获取原函数的参数个数 var args = []; // args存储传入参数 return function curryFn() { // 将arguments转换成数组 var curryArgs = Array.prototype.slice.call(arguments); args = args.concat(curryArgs); if (args.length > length) { throw new Error('arguments length error') } // 存储的参数个数等于原函数参数个数时执行原函数 if (args.length === length) { return fn.apply(null, args); } // 否则继续返回函数 return curryFn; }; }
function curry(fn) { let length = fn.length; let args = []; return function curryFn(...curryArgs) { args = args.concat(curryArgs); if (args.length > length) { throw new Error('arguments length error') } if (args.length === length) { return fn(...args); } return curryFn; } }
以上是JavaScript實作柯里化(curry)函數的想法與原始碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!