>  기사  >  백엔드 개발  >  如何以数组中对象的某个字段为基准重新排列数组的内容

如何以数组中对象的某个字段为基准重新排列数组的内容

WBOY
WBOY원래의
2016-06-06 20:28:341584검색

比如下面是我从数据库中读取出来的数据,然后我想以suppliers_id为基准重新排列这个数组,有什么比较好的方法?

<code>[
    {
        cart_id: "6",
        suppliers_id: "1",
        goods_name: "商品1",
    },
    {
        cart_id: "7",
        suppliers_id: "1",
        goods_name: "商品2",
    }
    {
        cart_id: "7",
        suppliers_id: "1",
        goods_name: "商品3",
    }
]</code>

变成

<code>[
    //suppliers_id
    1:
    [
        {
            cart_id: "6",
            suppliers_id: "1",
            goods_name: "商品1",
        },
        {
            cart_id: "7",
            suppliers_id: "1",
            goods_name: "商品3",
        }
    ]
    //suppliers_id
    2:
    [
        {
            cart_id: "7",
            suppliers_id: "1",
            goods_name: "商品2",
        }
    ]
]</code>

回复内容:

比如下面是我从数据库中读取出来的数据,然后我想以suppliers_id为基准重新排列这个数组,有什么比较好的方法?

<code>[
    {
        cart_id: "6",
        suppliers_id: "1",
        goods_name: "商品1",
    },
    {
        cart_id: "7",
        suppliers_id: "1",
        goods_name: "商品2",
    }
    {
        cart_id: "7",
        suppliers_id: "1",
        goods_name: "商品3",
    }
]</code>

变成

<code>[
    //suppliers_id
    1:
    [
        {
            cart_id: "6",
            suppliers_id: "1",
            goods_name: "商品1",
        },
        {
            cart_id: "7",
            suppliers_id: "1",
            goods_name: "商品3",
        }
    ]
    //suppliers_id
    2:
    [
        {
            cart_id: "7",
            suppliers_id: "1",
            goods_name: "商品2",
        }
    ]
]</code>

看到标签是 php 表示无能为力。

如果是在前端处理你倒是可以用 sort(function(a,b){}) 这种思路来。

使用PHP的uksort函数,这货可以接收两个参数

<code>$arr = [
{c:"213"}
,
{c:"dadad"}]
function compare_func($a, $b){
    return $a=>c - $b=>c;
}
uksrot($arr,"compare_func" );</code>
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.