javascript之典型高阶函数应用介绍二


Posted in Javascript onJanuary 10, 2013

前言
在前一篇文章javascript之典型高阶函数中主要实现了几个典型的functional函数。文章最后也提出了疑问,为啥那样的实现与F#之类的函数式语言“不太一样”呢?今天来试试更“函数式”的实现。

另一种实现
同样地,尝试对之前实现的函数做一些改动,把for循环去掉。如何去掉呢?这里先要引入一个集合的归纳法定义:

一个集合要么是空集,要么是一个数与一个集合组成的数对从定义可以看到,每一个集合都可以看作为一个数和一个集合的对。例如:{1,2,4,5} 可以认为是数 1 与 集合{2,4,5} 组成的一对,写成(1 , {2,4,5})。递归地,{2,4,5} 可以看成是(2 , {4,5})。最后即为 (5 , Ø)。按照这样的理解,我们就可以用递归的方法消除循环,因为我们在分解的时候已经访问了每一个数据项,并且终结条件为空集。下面就看一下filter函数的另一个实现,原函数名加前缀f以区别之前函数:

function ffilter(arr,callback){ 
var i=arguments[2] || 0, 
  out = arguments[3] || []; 
if(!arr[i]) return arguments[3]; 
if(callback(arr[i])) 
out.push(arr[i]); 
return arguments.callee(arr,callback,++i,out); 
}

测试:
var arr = [1,2,3,4,5,6,7,8,9,10]; 
var even = function(item){ 
if(typeof item !== "number") return false; 
return !(item & 1); 
}; 
console.log(ffilter(arr,even));

结果:
[2, 4, 6, 8, 10] 这样消除循环之后,更贴近于数学的归纳定义,显得更自然。同样地,再看一下ffold函数:
var arr = [1,2,3,4,5,6,7,8,9,10]; 
var plus = function(a,b){ 
return a+b; 
}; 
console.log(ffold(arr,plus,3));

结果:
58
其他函数以同样的方法即可。这样就感觉更functional 了,但能不能再与数学定义更加接近呢?下一次再尝试。
==========2013.1.8 更新==================
上面说到了那些写法能否与数学定义更加接近,下面就尝试一下使用链表。先给出一个定义:
var node = function(){ 
this.data = 0; 
this.tail = null; 
};

再初始化一个链表
var n1 = new node(),n2 = new node(),n3 = new node(),n4 = new node(),n5 = new node(); 
n1.data=1,n1.tail=n2; 
n2.data=2,n2.tail=n3; 
n3.data=3,n3.tail=n4; 
n4.data=4,n4.tail=n5; 
n5.data=5,n5.tail=null;

fold链表版本:
function lfold(head,callback,b){ 
if(!head) return b; 
else return callback(head.data,arguments.callee(head.tail,callback,b)); 
}

输出结果:
18
按照之前的定义,一个集合要么是空集,要么是一个“头”与一个“尾”(集合)组成的数对。每一次调用函数时,分解为head和tail,直到集合为空(写完上面的lfold函数真心感觉太完美了,简直就是定义,要是程序都长这样,注释都不需要了,真是一种享受)。这样子算是最接近数学定义的表示了。因为javascript不支持很多函数式语言的match,所以不能“自动”分解,也就不能直接表示归纳定义。

javascript除了以上的一些东西,还可以实现函数式里面的partial,dojo框架里面的hitch就做到了这一功能,这也是函数式贴近数学的另外一个明显的例子。我将在下一篇博客中讨论。

Javascript 相关文章推荐
JavaScript中的Array对象使用说明
Jan 17 Javascript
jquery load()在firefox(火狐)下显示不正常的解决方法
Apr 05 Javascript
JavaScript中判断函数是new还是()调用的区别说明
Apr 07 Javascript
JS 控制小数位数的实现代码
Aug 02 Javascript
JavaScript中__proto__与prototype的关系深入理解
Dec 04 Javascript
js计算精度问题小结
Apr 22 Javascript
JS可以控制样式的名称写法一览
Jan 16 Javascript
javascript中innerText和innerHTML属性用法实例分析
May 13 Javascript
用JavaScript来美化HTML的select标签的下拉列表效果
Nov 17 Javascript
JS iFrame加载慢怎么解决
May 13 Javascript
微信小程序实现action-sheet弹出底部菜单功能【附源码下载】
Dec 09 Javascript
jQuery实现动态添加和删除input框代码实例
Mar 29 jQuery
javascript之典型高阶函数应用介绍
Jan 10 #Javascript
根据json字符串生成Html的一种方式
Jan 09 #Javascript
web的各种前端打印方法之jquery打印插件jqprint实现网页打印
Jan 09 #Javascript
web的各种前端打印方法之jquery打印插件PrintArea实现网页打印
Jan 09 #Javascript
实现web打印的各种方法介绍及实现代码
Jan 09 #Javascript
js去除重复字符串两种实现方法
Jan 09 #Javascript
jquery插件之信息弹出框showInfoDialog(成功/错误/警告/通知/背景遮罩)
Jan 09 #Javascript
You might like
php&java(一)
2006/10/09 PHP
PHP与MySQL开发中页面乱码的产生与解决
2008/03/27 PHP
php中使用preg_replace函数匹配图片并加上链接的方法
2013/02/06 PHP
PHP的RSA加密解密方法以及开发接口使用
2018/02/11 PHP
Thinkphp5框架实现获取数据库数据到视图的方法
2019/08/14 PHP
限制文本字节数js代码
2007/03/06 Javascript
关于IE、Firefox、Opera页面呈现异同 写脚本很痛苦
2009/08/28 Javascript
extjs DataReader、JsonReader、XmlReader的构造方法
2009/11/07 Javascript
js 实现 input type="file" 文件上传示例代码
2013/08/07 Javascript
js添加select下默认的option的value和text的方法
2014/10/19 Javascript
AngularJS中如何使用$parse或$eval在运行时对Scope变量赋值
2016/01/25 Javascript
javascript中Date对象应用之简易日历实现
2016/07/12 Javascript
JavaScript正则获取地址栏中参数的方法
2017/03/02 Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
2017/12/27 Javascript
解决Webpack 热部署检测不到文件变化的问题
2018/02/22 Javascript
JS实现的透明度渐变动画效果示例
2018/04/28 Javascript
Vue验证码60秒倒计时功能简单实例代码
2018/06/22 Javascript
wxPython 入门教程
2008/10/07 Python
python使用BeautifulSoup分页网页中超链接的方法
2015/04/04 Python
Python+django实现文件上传
2016/01/17 Python
浅析Python中MySQLdb的事务处理功能
2016/09/21 Python
python与php实现分割文件代码
2017/03/06 Python
django rest framework之请求与响应(详解)
2017/11/06 Python
Python实现生成随机数据插入mysql数据库的方法
2017/12/25 Python
Python实现的圆形绘制(画圆)示例
2018/01/31 Python
对python多线程与global变量详解
2018/11/09 Python
python调用百度地图WEB服务API获取地点对应坐标值
2019/01/16 Python
python2.7 安装pip的方法步骤(管用)
2019/05/05 Python
在notepad++中实现直接运行python代码
2019/12/18 Python
详解Python多线程下的list
2020/07/03 Python
Python命令行参数argv和argparse该如何使用
2021/02/08 Python
关于探究python中sys.argv时遇到的问题详解
2021/02/23 Python
matplotlib之多边形选区(PolygonSelector)的使用
2021/02/24 Python
房屋租赁授权委托书范本
2014/09/20 职场文书
学校办公室主任岗位职责
2015/04/01 职场文书
党员反四风学习心得体会
2016/01/22 职场文书