如何通过嵌套对象属性对JavaScript对象数组进行排序?

Ver*_*onW 28 javascript arrays sorting

我有这个函数来根据属性对JavaScript对象数组进行排序:

// arr is the array of objects, prop is the property to sort by
var sort = function (prop, arr) {
    arr.sort(function (a, b) {
        if (a[prop] < b[prop]) {
            return -1;
        } else if (a[prop] > b[prop]) {
            return 1;
        } else {
            return 0;
        }
    });
};
Run Code Online (Sandbox Code Playgroud)

它适用于这样的数组:

sort('property', [
    {property:'1'},
    {property:'3'},
    {property:'2'},
    {property:'4'},
]);
Run Code Online (Sandbox Code Playgroud)

但是我希望能够通过嵌套属性进行排序,例如:

sort('nestedobj.property', [
    {nestedobj:{property:'1'}},
    {nestedobj:{property:'3'}},
    {nestedobj:{property:'2'}},
    {nestedobj:{property:'4'}}
]);
Run Code Online (Sandbox Code Playgroud)

然而,这不起作用,因为它不可能做类似的事情object['nestedobj.property'],它应该是object['nestedobj']['property'].

你知道我怎么能解决这个问题并使我的函数与嵌套对象的属性一起工作?

提前致谢

use*_*716 26

您可以拆分propon .,并迭代Array ,在每次迭代期间更新ab使用下一个嵌套属性.

示例: http ://jsfiddle.net/x8KD6/1/

var sort = function (prop, arr) {
    prop = prop.split('.');
    var len = prop.length;

    arr.sort(function (a, b) {
        var i = 0;
        while( i < len ) { a = a[prop[i]]; b = b[prop[i]]; i++; }
        if (a < b) {
            return -1;
        } else if (a > b) {
            return 1;
        } else {
            return 0;
        }
    });
    return arr;
};
Run Code Online (Sandbox Code Playgroud)


Anu*_*rag 7

不是将属性作为字符串传递,而是传递一个可以从顶级对象检索属性的函数.

var sort = function (propertyRetriever, arr) {
    arr.sort(function (a, b) {
        var valueA = propertyRetriever(a);
        var valueB = propertyRetriever(b);

        if (valueA < valueB) {
            return -1;
        } else if (valueA > valueB) {
            return 1;
        } else {
            return 0;
        }
    });
};
Run Code Online (Sandbox Code Playgroud)

调用为,

var simplePropertyRetriever = function(obj) {
    return obj.property;
};

sort(simplePropertyRetriever, { .. });
Run Code Online (Sandbox Code Playgroud)

或者使用嵌套对象,

var nestedPropertyRetriever = function(obj) {
    return obj.nestedObj.property;
};

sort(nestedPropertyRetriever, { .. });
Run Code Online (Sandbox Code Playgroud)


rat*_*rat 7

使用Array.prototype.sort()自定义比较函数首先进行降序排序:

champions.sort(function(a, b) { return b.level - a.level }).slice(...
Run Code Online (Sandbox Code Playgroud)

使用 ES6 更好:

champions.sort((a, b) => b.level - a.level).slice(...
Run Code Online (Sandbox Code Playgroud)


Mas*_*Mas 7

如果你有像这样的对象数组

const objs = [{
        first_nom: 'Lazslo',
        last_nom: 'Jamf',
        moreDetails: {
            age: 20
        }
    }, {
        first_nom: 'Pig',
        last_nom: 'Bodine',
        moreDetails: {
            age: 21
        }
    }, {
        first_nom: 'Pirate',
        last_nom: 'Prentice',
        moreDetails: {
            age: 22
        }
    }];
Run Code Online (Sandbox Code Playgroud)

你可以简单地使用

nestedSort = (prop1, prop2 = null, direction = 'asc') => (e1, e2) => {
        const a = prop2 ? e1[prop1][prop2] : e1[prop1],
            b = prop2 ? e2[prop1][prop2] : e2[prop1],
            sortOrder = direction === "asc" ? 1 : -1
        return (a < b) ? -sortOrder : (a > b) ? sortOrder : 0;
    }
Run Code Online (Sandbox Code Playgroud)

并称之为

对于直接对象

objs.sort(nestedSort("last_nom"));
objs.sort(nestedSort("last_nom", null, "desc"));
Run Code Online (Sandbox Code Playgroud)

对于嵌套对象

objs.sort(nestedSort("moreDetails", "age"));
objs.sort(nestedSort("moreDetails", "age", "desc"));
Run Code Online (Sandbox Code Playgroud)