什么是高阶函数?html
高阶函数是指至少知足下列条件之一的函数:node
1.函数能够做为参数被传递ajax
2.函数能够做为返回值输出json
1.函数做为参数传递,这样咱们能够抽离出一部分容易变化的业务逻辑,把这部分业务放在函数参数中,这样一来就能够分离业务代码中变化与不变的部分。常见的形式有:数组
1)回调函数app
常见的回调如ajax中:当咱们使用ajax发出请求,可是不知道请求返回的确切时间,咱们可使用回调来解决,将callback看成参数传入ajax请求的方法中,等请求完成后执行。异步
function getData(id, callback){ $.ajax({ type: 'GET', url: 'http://163.com/?getData='+id, dataType: 'json', success: function(data){ callback(data); } }) }
getData(12345, function(data){console.log(data)})
回调函数不只可使用在异步请求中:函数
假如咱们想在页面中建立一百个div节点,同时将这些节点都设置为隐藏,能够这么实现url
function appendDiv(){ for(var i = 0; i < 100; i++){ var div = document.createElement('div'); div.innerHTML = i; document.body.append(div); div.style.display = 'none'; } } appendDiv()
这样写看似没有问题,可是当咱们下次修改需求,将100个div改变背景颜色,这段代码就难以复用了。咱们能够这样:spa
function appendDiv(callback){ for(var i = 0; i < 100; i++){ var div = document.createElement('div'); div.innerHTML = i; document.body.append(div); if(callback && typeof callback === 'function'){ callback(div) } } } appendDiv(function(node){ node.style.display = 'none' })
经过使用回调,将业务代码将在回调函数中,能够抽离出一部分业务代码,对代码复用有很大的帮助。若是后期须要修改需求,改变颜色,改变大小等等只须要从新写回调函数便可。
2)Array.prototype.sort,该方法接受一个函数做为参数,这个函数告诉Array的排序规则,经过定义不一样的方法实现不一样的排序,使得sort很是灵活。
[1, 3, 4, 2].sort(function(a, b){ return a-b; }) //输出[1, 2, 3, 4] [1, 3, 4, 2].sort(function(a, b){ return b-a; }) //输出[4, 3, 2, 1]
2.函数做为返回值输出
1)判断数据的类型
如以前的文章 http://www.cnblogs.com/ppforever/p/4362102.html 判断一个js对象是否是数组,将函数做为返回值。稍加扩展:
var isType = function(type){ //函数做为返回值 return function(obj){ return Object.prototype.toString.call(obj) === '[object '+ type +']'; } } var isArray = isType('Array'); var isString = isType('String'); var isNumber = isType('Number'); console.log(isArray([1, 6, 3])) //true
咱们也可使用循环语句,批量注册isType方法:
var Type = {}; for(var i = 0, type; type = ['String', 'Array', 'Number'][i++]; ){ (function(type){ Type['is'+type] = function(obj){
return Object.prototype.toString.call(obj) === '[object '+ type +']'; } })(type) } Type.isArray([]); //true Type.isString('abc'); //true Type.isNumber(123); //true Type.isArray(123); //false
上部分主要介绍高阶函数的常见形式,下部分将着重介绍高阶函数的高级应用。