lodash orderBy on nested property

痴心易碎 提交于 2019-11-30 06:55:39

问题


I'm using v4.11.0. I would like sort objects based on milliseconds property. Here's the array :

[
    {
        "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
        }
    }
]

I'm missing something fundamental about the iteratee function. I have this but does not seem to sort the array. Thanks in advance!

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

回答1:


It seems that you are ordering by the property value.

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



回答2:


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

A simple example on how you can use the Lodash: orderBy to sort based on inner attributes.

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



来源:https://stackoverflow.com/questions/36606105/lodash-orderby-on-nested-property

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!