摘要:改为下面这样子的代码初始的执行其实只实现了部分的应用只有一次的判定,而剩余的参数应用都是其返回函数实现的,典型的柯里化。
今天接触到了一个之前没听说过的东东,感觉很好玩~分享给大家~为了彻底的了解一下相关概念,特意拜读了一下张鑫旭大神的相关文章链接如下~:
http://www.zhangxinxu.com/wor...
感谢大神分享,本文将截取大神分享的部分及加上自己的小小理解~
先发一波定义~(源自百度百科)
在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。这个技术由 Christopher Strachey 以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的。
大神用于函数柯里化用的比喻相当的形象非常有助于理解~
“柯里化”就像某些官员的把戏,官员要弄7个老婆,碍于国策(一夫一妻)以及年老弟衰,表面上就1个老婆,实际上剩下的6个暗地里消化,代码表示如下:
var curring = function(fn){ // fn 指官员消化老婆的手段 var args = [].slice.call(arguments,1); // 截取arguments中的第一个生成一个数组,也就是当前语境下的明面上的合法老婆 return function(){ // 将已有的参数和新传进来的参数合并为一个数组,对应已有的合法老婆和新搞定的老婆 var newArgs = args.concat([].slice.call(arguments)); // 将所有的参数newArgs绑定给fn~ return fn.apply(null,newArgs); } } // 下面为官员如何搞定7个老婆做测试 // 获得合法老婆 var getWife = currying(function(){ var allWife = [].slice.call(arguments); console.log(allWife.join(";")) },"合法老婆"); // 获得其他6个老婆 getWife("小老婆1","小老婆2","小老婆3","小老婆4","小老婆5","小老婆6"); // 换一批老婆 getWife("大老婆","小老婆","俏老婆","刁蛮老婆","乖老婆","送上门老婆"); // 再换一批老婆 getWife("超越韦小宝的老婆");
效果是这样的~
无论输入多少个参数,都会打印输出,且都会带着第一个参数~
上文代码fn.apply(null,newArgs)中的null本是应该制定fn中this的指向的对象,没有所以就用null啦,算是一个小技巧~
理解理解之后再想想,这个东西有什么用啊~~
柯里化有三个常见的应用:
参数复用(上文代码中的合法老婆)
提前返回
这里举个很实用的例子,兼容现代浏览器以及IE浏览器的事件添加方法:
var addEvent = function(el, type, fn, capture) { if (window.addEventListener) { el.addEventListener(type, function(e) { fn.call(el, e); }, capture); } else if (window.attachEvent) { el.attachEvent("on" + type, function(e) { fn.call(el, e); }); } };
上面的方法有什么问题呢?很显然,我们每次使用addEvent为元素添加事件的时候,(eg. IE6/IE7)都会走一遍if...else if ...,其实只要一次判定就可以了,怎么做?–柯里化。改为下面这样子的代码:
var addEvent = (function(){ if (window.addEventListener) { return function(el, sType, fn, capture) { el.addEventListener(sType, function(e) { fn.call(el, e); }, (capture)); }; } else if (window.attachEvent) { return function(el, sType, fn, capture) { el.attachEvent("on" + sType, function(e) { fn.call(el, e); }); }; } })();
初始addEvent的执行其实只实现了部分的应用(只有一次的if...else if...判定),而剩余的参数应用都是其返回函数实现的,典型的柯里化。
第三个常见应用: 延迟计算
var curryWeight = function(fn) { var _weight = []; return function() { if (arguments.length === 0) { return fn.apply(null, _weight); } else { _weight = _weight.concat([].slice.call(arguments)); } } }; var weight = 0; var addWeight = curryWeight(function() { var i=0; len = arguments.length; for (i; i先传入参数,直到调用的时候才执行计算~
今天的分享就先到这里了~愿与各位共勉~
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/93226.html
摘要:柯里化通用式上面的柯里化函数没涉及到高阶函数,也不具备通用性,无法转换形参个数任意或未知的函数,我们接下来封装一个通用的柯里化转换函数,可以将任意函数转换成柯里化。 showImg(https://segmentfault.com/img/remote/1460000018998373); 阅读原文 前言 在 JavaScript 中,柯里化和反柯里化是高阶函数的一种应用,在这之前...
摘要:函数柯里化是把支持多个参数的函数变成接收单一参数的函数,并返回一个函数能接收处理剩余参数,而反柯里化就是把参数全部释放出来。但在一些复杂的业务逻辑封装中,函数柯里化能够为我们提供更好的应对方案,让我们的函数更具自由度和灵活性。 showImg(https://segmentfault.com/img/bVburN1?w=800&h=600); 柯里化(Curring, 以逻辑学家Has...
摘要:作为函数式编程语言,带来了很多语言上的有趣特性,比如柯里化和反柯里化。在一些函数式编程语言中,会定义一个特殊的占位变量。个人理解不知道对不对延迟执行柯里化的另一个应用场景是延迟执行。不断的柯里化,累积传入的参数,最后执行。作为函数式编程语言,JS带来了很多语言上的有趣特性,比如柯里化和反柯里化。 这里可以对照另外一篇介绍 JS 反柯里化 的文章一起看~ 1. 简介 柯里化(Currying)...
摘要:作为函数式编程语言,带来了很多语言上的有趣特性,比如柯里化和反柯里化。个人理解不知道对不对延迟执行柯里化的另一个应用场景是延迟执行。不断的柯里化,累积传入的参数,最后执行。 作为函数式编程语言,JS带来了很多语言上的有趣特性,比如柯里化和反柯里化。 这里可以对照另外一篇介绍 JS 反柯里化 的文章一起看~ 1. 简介 柯里化(Currying),又称部分求值(Partial Evalu...
摘要:如果你对函数式编程有一定了解,函数柯里化是不可或缺的,利用函数柯里化,可以在开发中非常优雅的处理复杂逻辑。同样先看简单版本的方法,以方法为例,代码来自高级程序设计加强版实现上面函数,可以换成任何其他函数,经过函数处理,都可以转成柯里化函数。 我们经常说在Javascript语言中,函数是一等公民,它们本质上是十分简单和过程化的。可以利用函数,进行一些简单的数据处理,return 结果,...
摘要:函数被转化之后得到柯里化函数,能够处理的所有剩余参数。因此柯里化也被称为部分求值。那么函数的柯里化函数则可以如下因此下面的运算方式是等价的。而这里对于函数参数的自由处理,正是柯里化的核心所在。额外知识补充无限参数的柯里化。 showImg(https://segmentfault.com/img/remote/1460000008493346); 柯里化是函数的一个比较高级的应用,想要...
阅读 1548·2021-11-25 09:43
阅读 2445·2019-08-30 15:54
阅读 2908·2019-08-30 15:53
阅读 1065·2019-08-30 15:53
阅读 717·2019-08-30 15:52
阅读 2509·2019-08-26 13:36
阅读 780·2019-08-26 12:16
阅读 1170·2019-08-26 12:13