zoukankan      html  css  js  c++  java
  • 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([]); //true Type.isString('abc'); //true Type.isNumber(123); //true Type.isArray(123); //false
    复制代码

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

      

  • 相关阅读:
    [USACO4.2]草地排水Drainage Ditches
    bzoj3236:[AHOI2013]作业
    小A买彩票-(组合数)
    CSS样式整理大全
    P1880 [NOI1995]石子合并-(环形区间dp)
    P1147连续自然数和-(尺取法)
    POJ2456Aggressive cows-(二分判定)
    NYOJ737石子合并(二)-(区间dp)
    牛客网-乌龟跑步-(dfs)
    int和string之间的转换
  • 原文地址:https://www.cnblogs.com/douglasvegas/p/4723745.html
Copyright © 2011-2022 走看看