温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JavaScript里的柯里化与反柯里化是什么意思

发布时间:2021-08-31 11:28:01 来源:亿速云 阅读:102 作者:chen 栏目:开发技术

本篇内容主要讲解“JavaScript里的柯里化与反柯里化是什么意思”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript里的柯里化与反柯里化是什么意思”吧!

我们先来简单了解一下他们的作用。

  柯里化又称部分求值,字面意思就是不会立刻求值,而是到了需要的时候再去求值。如果看的懵逼,没事,看完整篇文章再回过头来看这里你就会豁然开朗。

  反柯里化的作用是,当我们调用某个方法,不用考虑这个对象在被设计时,是否拥有这个方法,只要这个方法适用于它,我们就可以对这个对象使用它。

  柯里化(curring)

  我们有这样一个场景,记录程序员一个月的加班总时间,那么好,我们首先要做的是记录程序员每天加班的时间,然后把一个月中每天的加班的时间相加,就得到了一个月的加班总时间。

  但问题来了,我们有很多种方法可以实现它,比如最简单的:

  varmonthTime=0;functionovertime(time){returnmonthTime+=time;}overtime(3.5);//第一天overtime(4.5);//第二天overtime(2.1);//第三天//...console.log(monthTime);//10.1

  每次传入加班时间都进行累加,这样当然没问题,但你知道,如果数据量很大的情况下,这样会大大牺牲性能。

那怎么办?这就是柯里化要解决的问题。

  其实我们不必每天都计算加班时间,只需要保存好每天的加班时间,在月底时计算这个月总共的加班时间,所以,其实只需要在月底计算一次就行。

  2011年JavaScript之父BrendanEich发表了一篇Twitter,提出了反柯里化这个思想,下面这段代码是反柯里化的实现方式之一:

  Function.prototype.uncurring=function(){varself=this;returnfunction(){varobj=Array.prototype.shift.call(arguments);returnself.apply(obj,arguments);};};

  我们先来看看上面这段代码有什么作用。

  我们要把Array.prototype.push方法转换成一个通用的push函数,只需要这样做:

  varpush=Array.prototype.push.uncurring();//测试一下(function(){push(arguments,4);console.log(arguments);//[1,2,3,4]})(1,2,3)

  arguments本来是没有push方法的,通常,我们都需要用Array.prototype.push.call来实现push方法,但现在,直接调用push函数,既简洁又意图明了。

到此,相信大家对“JavaScript里的柯里化与反柯里化是什么意思”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI