你的位置:首页 > Java教程

[Java教程]JavaScript设计模式与开发实践——读书笔记1.高阶函数(上)


  说来惭愧,4个多月未更新了。4月份以后就开始忙起来了,论文、毕设、毕业旅行等七七八八的事情占据了很多时间,毕业之后开始忙碌的工作,这期间一直想写博客,但是一直没能静下心写。这段时间在看《JavaScript设计模式与开发实践》,感觉很不错,受益匪浅。

  这篇文章将围绕高阶函数是什么、高阶函数有什么作用等几个方面来进行介绍。

  什么是高阶函数?

  高阶函数是指至少满足下列条件之一的函数:

  1.函数可以作为参数被传递

  2.函数可以作为返回值输出

  

  1.函数作为参数传递,这样我们可以抽离出一部分容易变化的业务逻辑,把这部分业务放在函数参数中,这样一来就可以分离业务代码中变化与不变的部分。常见的形式有:

  1)回调函数

  常见的回调如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节点,同时将这些节点都设置为隐藏,可以这么实现

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改变背景颜色,这段代码就难以复用了。我们可以这样:

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([]); //trueType.isString('abc');//trueType.isNumber(123);//trueType.isArray(123);//false

  上部分主要介绍高阶函数的常见形式,下部分将着重介绍高阶函数的高级应用。