curry化 js_JavaScript实现柯里化(curry)函数的思路和源码

本文详细介绍了JavaScript中实现柯里化函数的思路和源码,包括传统版本和ES6版本的实现方式。通过闭包存储传入参数,利用函数length属性判断参数个数,当达到原函数所需参数时执行原函数。提供了两种实现方法的源码,帮助开发者理解柯里化的应用。
摘要由CSDN通过智能技术生成

本篇文章给大家带来的内容是关于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;

};

}

ES6版

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;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值