javascript,将一个函数作为另一个函数的返回值(必要)。

//先定义一个数组
var studentsData = [{
        name: "mike",
        age: 17
    },
    {
        name: "loren",
        age: 16
    },
    {
        name: "frank",
        age: 18
    }
];
//将数组按姓名排序
function compareFunctionByName(object1, object2) {
    var value1 = object1["name"];
    var value2 = object2["name"];
    if (value1 < value2) {
        return -1;
    } else if (value1 == value2) {
        return 0;
    } else {
        return 1;
    }
};
studentsData.sort(compareFunctionByName);  
//compareFunctionByName不用传参,原因是因为这个函数作为排序的规则传给了这个sort方法
//按姓名排序结果如下图:

javascript,将一个函数作为另一个函数的返回值(必要)。_第1张图片

//将数组按年龄排序
function compareFunctionByAge(object1, object2) {
    var value1 = object1["age"];
    var value2 = object2["age"];
    if (value1 < value2) {
        return -1;
    } else if (value1 == value2) {
        return 0;
    } else {
        return 1;
    }
};
studentsData.sort(compareFunctionByAge);
//按年龄排序结果如下图:

javascript,将一个函数作为另一个函数的返回值(必要)。_第2张图片

//这样的排序写法简单有效,但是,如果此时需求变更,除了name外还需要对学生的age进行排序时,
//一般的做法是另外写一个按照age字段进行排序的比较函数,如果排序需求字段过多的话,代码的
//冗余度大大增加。
function createCompareFunction(fieldName) {
    return function (object1, object2) {
        var value1 = object1[fieldName];
        var value2 = object2[fieldName];
        if (value1 < value2) {
            return -1;
        } else if (value1 == value2) {
            return 0;
        } else {
            return 1;
        }
    };
}

//按照name字段进行排序
studentsData.sort(createCompareFunction("name"));

//按照age字段进行排序
studentsData.sort(createCompareFunction("age"));

//如果将一个函数作为另一个函数的返回值,便解决了高冗余度的问题

你可能感兴趣的:(javascript,将一个函数作为另一个函数的返回值(必要)。)