首页
Javascript
Html
Css
Node.js
Electron
移动开发
工具类
服务端
浏览器相关
前端收藏
其他
关于

理解javascript函数柯里化(Currying)

2012年11月05日 发布 阅读(321) 作者:懒炖

1、什么是“柯里化”?

在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。这个技术由Christopher Strachey 以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的。

在直觉上,柯里化声称“如果你固定某些参数,你将得到接受余下参数的一个函数”。所以对于有两个变量的函数yx,如果固定了 y = 2,则得到有一个变量的函数 2x。

2、在多参数的函数中,如果我们想固定其中的一个参数(即有一个参数绐终是不变的),我们就可以使用函数的柯里化特性。柯里化就是预先将函数的某些参数传入,得到一个简单的函数,预先传入的参数被保存在闭包中。

如:

  1. var adder = function(num){
  2. return function(y){
  3. return num + y;
  4. }
  5. }
  6. var inc = adder(1);
  7. //inc返回函数为
  8. inc = function (y){
  9. return num + y;
  10. }
  11. //adder(1)相当于
  12. inc = function (y){
  13. return 1 + y; //num保存在闭包当中,其值为1
  14. }
  15. //根据上面的函数我们来计算下面的结果就容易了
  16. inc(100); //101
  17. adder(-100)(101); //1;

3、函数柯里化的一个应用

  1. //update会返回一个函数,这个函数可以设置id属性为item的web元素的内容
  2. function update(item){
  3. return function(text){
  4. $("div#"+item).html(text);
  5. }
  6. }
  7. //Ajax请求,当成功是调用参数callback
  8. function refresh(url, callback){
  9. var params = {
  10. type : "echo",
  11. data : ""
  12. };
  13. $.ajax({
  14. type:"post",
  15. url:url,
  16. cache:false,
  17. async:true,
  18. dataType:"json",
  19. data:params,
  20. //当异步请求成功时调用
  21. success: function(data, status){
  22. callback(data);
  23. },
  24. //当请求出现错误时调用
  25. error: function(err){
  26. alert("error : "+err);
  27. }
  28. });
  29. }
  30. refresh("action.do?target=news", update("newsPanel"));
  31. refresh("action.do?target=articles", update("articlePanel"));
  32. refresh("action.do?target=pictures", update("picturePanel"));

其中,update函数即为柯里化的一个实例,它会返回一个函数。如

  1. update("newsPanel") = function(text){
  2. $("div#newsPanel").html(text);
  3. }

由于update(“newsPanel”)的返回值为一个函数,需要的参数为一个字符串,因此在refresh的Ajax调用中,当success时,会给callback传入服务器端返回的数据信息,从而实现newsPanel面板的刷新,其他的文章面板articlePanel,图片面板picturePanel的刷新均采取这种方式,这样,代码的可读性,可维护性均得到了提高。

版权声明:本站文章除特别声明外,均采用署名-非商业性使用-禁止演绎 4.0 国际 许可协议,如需转载,请注明出处

评论

  •