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 相关文章推荐
获取页面高度,窗口高度,滚动条高度等参数值getPageSize,getPageScroll
Sep 22 Javascript
网络图片延迟加载实现代码 超越jquery控件
Mar 27 Javascript
用js实现的模拟jquery的animate自定义动画(2.5K)
Jul 20 Javascript
从数据结构分析看:用for each...in 比 for...in 要快些
Apr 17 Javascript
基于javascript 闭包基础分享
Jul 10 Javascript
js验证电话号码与手机支持+86的正则表达式
Jan 23 Javascript
BootStrap中Datetimepicker和uploadify插件应用实例小结
May 26 Javascript
微信小程序 教程之列表渲染
Oct 18 Javascript
详谈js中window.location.search的用法和作用
Feb 13 Javascript
Vue组件模板形式实现对象数组数据循环为树形结构(实例代码)
Jul 31 Javascript
深入理解Vue.js轻量高效的前端组件化方案
Dec 10 Javascript
vue+springboot实现登录验证码
May 27 Vue.js
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
重置版游戏视频
2020/04/09 魔兽争霸
用PHP和ACCESS写聊天室(二)
2006/10/09 PHP
兼容各大浏览器带关闭按钮的漂浮多组图片广告代码
2014/06/05 PHP
php实现事件监听与触发的方法
2014/11/21 PHP
通过php修改xml文档内容的方法
2015/01/23 PHP
Yii2主题(Theme)用法详解
2016/07/23 PHP
PHP PDOStatement::debugDumpParams讲解
2019/01/30 PHP
JS 文件本身编码转换 图文教程
2009/10/12 Javascript
Jquery刷新页面背景图片随机变换的实现方法
2013/03/15 Javascript
使用jquery实现简单的ajax
2013/07/08 Javascript
jQuery代码实现发展历程时间轴特效
2015/07/30 Javascript
jQuery模拟原生态App上拉刷新下拉加载更多页面及原理
2015/08/10 Javascript
深入理解Javascript中的作用域链和闭包
2017/04/25 Javascript
JavaScript时间戳与时间日期间相互转换
2017/12/11 Javascript
jQuery 实现倒计时天,时,分,秒功能
2018/07/31 jQuery
Vue.js中provide/inject实现响应式数据更新的方法示例
2019/10/16 Javascript
在vue项目实现一个ctrl+f的搜索功能
2020/02/28 Javascript
[30:37]【全国守擂赛】第三周擂主赛 Dark Knight vs. Leopard Gaming
2020/05/04 DOTA
python过滤字符串中不属于指定集合中字符的类实例
2015/06/30 Python
python的keyword模块用法实例分析
2015/06/30 Python
Python yield的用法实例分析
2020/03/06 Python
基于Python实现下载网易音乐代码实例
2020/08/10 Python
python复合条件下的字典排序
2020/12/18 Python
英国门销售网站:Green Tree Doors
2020/01/07 全球购物
如何在Oracle中查看各个表、表空间占用空间的大小
2015/10/31 面试题
学校后勤岗位职责
2014/02/19 职场文书
给校长的建议书500字
2014/05/15 职场文书
事业单位鉴定材料
2014/05/25 职场文书
个人租房协议书(范本)
2014/10/14 职场文书
再婚婚前财产协议书范本
2014/10/19 职场文书
2014年幼儿园保育工作总结
2014/12/02 职场文书
离婚纠纷代理词
2015/05/23 职场文书
无犯罪记录证明样本
2015/06/16 职场文书
表彰大会新闻稿
2015/07/17 职场文书
2015年教务主任工作总结
2015/07/22 职场文书
单位车辆管理制度
2015/08/05 职场文书