web-dev-qa-db-fra.com

ordre de dépôt par propriété imbriquée

J'utilise v4.11.0. Je voudrais trier les objets en fonction de la propriété milliseconds. Voici le tableau:

[
    {
        "name": "bug12755.xml",
        "list": "bugs42",
        "start-date": "2015-09-14",
        "age": {
            "text": "7 months",
            "milliseconds": 18381227304
        }
    },
    {
        "name": "bug12922.xml",
        "list": "bugs42",
        "start-date": "2015-08-27",
        "age": {
            "text": "8 months",
            "milliseconds": 19936427304
        }
    },
    {
        "name": "bug13183.xml",
        "list": "bugs50",
        "start-date": "2015-08-27",
        "age": {
            "text": "8 months",
            "milliseconds": 19936427305
        }
    }
]

Il me manque quelque chose de fondamental à propos de la fonction iteratee. J'ai ceci mais ne semble pas trier le tableau. Merci d'avance!

 _.orderBy(list, function(item) {
            return item.age.value;
        }, ['desc']);
23
Sudhakar

Il semble que vous passiez une commande par la propriété value.

u.orderBy(list, function(e) { return e.age.milliseconds}, ['desc']);
26
JesusTinoco

https://codepen.io/a2qube/pen/pKYrgN

Un exemple simple sur la façon dont vous pouvez utiliser Lodash: orderBy pour trier en fonction des attributs internes.

hotels = _.orderBy(hotels, 'account.id', 'desc');

17
Arjun Nair