//先定义一个数组
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方法
//按姓名排序结果如下图:
//将数组按年龄排序
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);
//按年龄排序结果如下图:
这样的排序写法简单有效,但是,如果此时需求变更,除了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"));
//如果将一个函数作为另一个函数的返回值,便解决了高冗余度的问题