Javascript闭包与函数柯里化浅析


Posted in Javascript onJune 22, 2016

闭包和柯里化都是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的刷新均采取这种方式,这样,代码的可读性,可维护性均得到了提高。

以上就是本文的全部内容,了解更多JavaScript的语法,大家可以查看:《JavaScript 参考教程》、《JavaScript代码风格指南》,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
sina的lightbox效果。
Jan 09 Javascript
node.js中的buffer.fill方法使用说明
Dec 14 Javascript
promise和co搭配生成器函数方式解决js代码异步流程的比较
May 25 Javascript
浅谈redux以及react-redux简单实现
Aug 28 Javascript
Vue前后端不同端口的实现方法
Sep 19 Javascript
深入理解Angularjs 脏值检测
Oct 12 Javascript
Angular使用Restful的增删改
Dec 28 Javascript
ES6 Array常用扩展的应用实例分析
Jun 26 Javascript
在layui tab控件中载入外部html页面的方法
Sep 04 Javascript
Vue el-autocomplete远程搜索下拉框并实现自动填充功能(推荐)
Oct 25 Javascript
JavaScript内置对象之Array的使用小结
May 12 Javascript
javascript运行机制之执行顺序理解
Aug 03 Javascript
JS中innerHTML和pasteHTML的区别实例分析
Jun 22 #Javascript
JS实现pasteHTML兼容ie,firefox,chrome的方法
Jun 22 #Javascript
浅析JavaScript中命名空间namespace模式
Jun 22 #Javascript
Javascript实现图片不间断滚动的代码
Jun 22 #Javascript
Javascript将双字节字符转换成单字节字符并计算长度
Jun 22 #Javascript
jQuery实现指定区域外单击关闭指定层的方法【经典】
Jun 22 #Javascript
Javascript 5种方法实现过滤删除前后所有空格
Jun 22 #Javascript
You might like
PHP连接MongoDB示例代码
2012/09/06 PHP
通过php添加xml文档内容的方法
2015/01/23 PHP
php列出mysql表所有行和列的方法
2015/03/13 PHP
PHP-FPM实现性能优化
2016/03/31 PHP
IE中jscript/javascript的条件编译
2006/09/07 Javascript
你真的了解JavaScript吗?
2007/02/24 Javascript
javascript js cookie的存储,获取和删除
2007/12/29 Javascript
[原创]用javascript实现检测指定目录是否存在的方法
2008/01/12 Javascript
js防止表单重复提交实现代码
2012/09/05 Javascript
php对mongodb的扩展(小试牛刀)
2012/11/11 Javascript
浅谈JavaScript函数参数的可修改性问题
2013/12/05 Javascript
解决JQeury显示内容没有边距内容紧挨着浏览器边线
2013/12/20 Javascript
延时加载JavaScript代码提高速度
2015/12/27 Javascript
利用VUE框架,实现列表分页功能示例代码
2017/01/12 Javascript
JS优化与惰性载入函数实例分析
2017/04/06 Javascript
JavaScript禁止微信浏览器下拉回弹效果
2017/05/16 Javascript
vue中axios实现数据交互与跨域问题
2019/05/12 Javascript
nodejs实现用户登录路由功能
2019/05/22 NodeJs
恢复百度云盘本地误删的文件脚本(简单方法)
2017/10/21 Python
Python 判断 有向图 是否有环的实例讲解
2018/02/01 Python
详解Django+Uwsgi+Nginx 实现生产环境部署
2018/11/06 Python
django中使用POST方法获取POST数据
2019/08/20 Python
python实现的config文件读写功能示例
2019/09/24 Python
使用Python实现正态分布、正态分布采样
2019/11/20 Python
序列化Python对象的方法
2020/08/01 Python
HTML5添加禁止缩放功能
2017/11/03 HTML / CSS
美国面料纺织品商城:Fabric.com
2017/06/28 全球购物
英国最大的汽车配件在线商店:Euro Car Parts
2019/09/30 全球购物
俄罗斯隐形眼镜和眼镜在线商店:Cronos
2020/06/02 全球购物
幼儿园秋游感想
2014/03/12 职场文书
新手上路标语
2014/06/20 职场文书
舞出我人生观后感
2015/06/16 职场文书
消防演习感想
2015/08/10 职场文书
3招让你摆脱即兴讲话冷场尴尬
2019/08/08 职场文书
《家世》读后感:看家训的力量
2019/12/30 职场文书
教你修复 Win11应用商店加载空白问题
2021/12/06 数码科技