博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(转)闭包与柯里化
阅读量:5105 次
发布时间:2019-06-13

本文共 2372 字,大约阅读时间需要 7 分钟。

闭包和柯里化都是JavaScript经常用到而且比较高级的技巧,所有的函数式编程语言都支持这两个概念,因此,我们想要充分发挥出JavaScript中的函数式编程特征,就需要深入的了解这两个概念,闭包事实上更是柯里化所不可缺少的基础。

      一、柯里化的概念
      在计算机科学中,柯里化是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。这个技术由Christopher Strachey以逻辑学家 Haskell Curry 命名的,尽管它是 Moses Schnfinkel 和 Gottlob Frege 发明的。在直觉上,柯里化声称“如果你固定某些参数,你将得到接受余下参数的一个函数”。所以对于有两个变量的函数yx,如果固定了y = 2,则得到有一个变量的函数2x。
      柯里化就是预先将函数的某些参数传入,得到一个简单的函数。但是预先传入的参数被保存在闭包中,因此会有一些奇特的特性。比如:

var adder = function(num){            return function(y){                  return num + y;            }      }      var inc = adder(1);      var dec = adder(-1)

这里的inc/dec两个变量事实上是两个新的函数,可以通过括号来调用,比如下例中的用法:

//inc, dec现在是两个新的函数,作用是将传入的参数值(+/-)1      print(inc(99));//100      print(dec(101));//100      print(adder(100)(2));//102      print(adder(2)(100));//102

二、柯里化的应用

      根据柯里化的特性,我们可以写出更有意思的代码,比如在前端开发中经常会遇到这样的情况,当请求从服务端返回后,我们需要更新一些特定的页面元素,也就是局部刷新的概念。使用局部刷新非常简单,但是代码很容易写成一团乱麻。而如果使用柯里化,则可以很大程度上美化我们的代码,使之更容易维护。我们来看一个例子:

//update会返回一个函数,这个函数可以设置id属性为item的web元素的内容      function update(item){            return function(text){                  $("div#"+item).html(text);            }      }      //Ajax请求,当成功是调用参数callback      function refresh(url, callback){            var params = {                  type : "echo",                  data : ""            };            $.ajax({                  type:"post",                  url:url,                  cache:false,                  async:true,                  dataType:"json",                  data:params,                  //当异步请求成功时调用                  success: function(data, status){                        callback(data);                  },                  //当请求出现错误时调用                  error: function(err){                        alert("error : "+err);                  }            });      }      refresh("action.do?target=news", update("newsPanel"));      refresh("action.do?target=articles", update("articlePanel"));      refresh("action.do?target=pictures", update("picturePanel"));      其中,update函数即为柯里化的一个实例,它会返回一个函数,即:      update("newsPanel") = function(text){            $("div#newsPanel").html(text);      }

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

 

转自:

其它相关文章:

 

      

转载于:https://www.cnblogs.com/mofish/archive/2013/03/30/2990488.html

你可能感兴趣的文章
好莱坞十大导演排名及其代表作,你看过多少?
查看>>
JVM-class文件完全解析-类索引,父类索引和索引集合
查看>>
Loj #139
查看>>
StringBuffer是字符串缓冲区
查看>>
hihocoder1187 Divisors
查看>>
java入门
查看>>
Spring 整合 Redis
查看>>
Azure 托管镜像和非托管镜像对比
查看>>
SQLite3初探
查看>>
多线程/多进程/异步IO
查看>>
leetcode 442. 数组中重复的数据 java
查看>>
struts2 文件上传下载注解示例
查看>>
编写一个简单的JAVA WEB Servlet页面
查看>>
JSP:Cookie实现永久登录(书本案例)
查看>>
js window.open 参数设置
查看>>
032. asp.netWeb用户控件之一初识用户控件并为其自定义属性
查看>>
linux--GCC用法
查看>>
Ubuntu下安装MySQL及简单操作
查看>>
OWIN是什么?
查看>>
前端监控
查看>>