«

js 二维数组按照指定 key 的顺序排序

时间:2024-2-22 14:08     作者:韩俊     分类: Javascript


JavaScript 针对二维数组按照指定的 key 的顺序进行排序,主要使用到了 sort() 方法,该方法主要用于对数组的元素进行排序。

sort() 方法有一个可选参数。但是,此参数必须是函数。 

数组在调用 sort() 方法时,如果没有传参将按字母顺序(字符编码顺序)对数组中的元素进行排序,如果想按照其他标准进行排序,就需要进行传一个参数且为函数,该函数要比较两个值,并且会返回一个用于说明这两个值的相对顺序的数字。

下面用三个示例进行说明:

1、对数字数组进行由小到大的顺序进行排序。

var arr = [22, 12, 3, 43, 56, 47, 4];
arr.sort();
console.log(arr); // [12, 22, 3, 4, 43, 47, 56]
arr.sort(function (m, n) {
    if (m < n) return -1;
    else if (m > n) return 1;
    else return 0;
});
console.log(arr); //结果:[3, 4, 12, 22, 43, 47, 56]

2、对字符串数组执行不区分大小写的字母表排序。

var arr = ['abc', 'Def', 'BoC', 'FED'];
console.log(arr.sort()); // ["BoC", "Def", "FED", "abc"]
console.log(arr.sort(function (s, t) {
    var a = s.toLowerCase(), b = t.toLowerCase();
    if (a < b) return -1;
    if (a > b) return 1;
    return 0;
}));
console.log(arr);//结果:["abc", "BoC", "Def", "FED"]

3、对包含对象的数组排序,要求根据对象中的年龄进行由大到小的顺序排列

var arr = [{'name': '张三', age: 26}, {'name': '李四', age: 12}, {'name': '王五', age: 37}, {'name': '赵六', age: 4}];
var objectArraySort = function (keyName) {
    return function (objectN, objectM) {
        var valueN = objectN[keyName], valueM = objectM[keyName];
        if (valueN < valueM) return 1;
        else if (valueN > valueM) return -1;
        else return 0;
    }
};
arr.sort(objectArraySort('age'));
console.log(arr) //结果:[{'name': '王五', age: 37},{'name': '张三', age: 26},{'name': '李四', age: 12},{'name': '赵六', age: 4}]

标签: javascript

热门推荐