0

私はこのSQLテーブルを持っています

私はこのSQLテーブルを持っています

phpのように返すには?

Root1
- SubCat 1
-- SubSubCat 1
- SubCat 2
Root2

これを見つけましが、必要な形で返すことができません。ただし、スクリプトは、最初はサブとして、次にルートとして、すべてのカテゴリを表示します。

作り方は?

4

1 に答える 1

1

これは仕事をします:

$items = array(
        (object) array('id' => 42, 'sub_id' => 1),
        (object) array('id' => 43, 'sub_id' => 42),
        (object) array('id' => 1, 'sub_id' => 0),
);

$childs = array();

foreach($items as $item)
    $childs[$item->sub_id][] = $item;

foreach($items as $item) if (isset($childs[$item->id]))
    $item->childs = $childs[$item->id];

$tree = $childs[0];

print_r($tree);

これは、最初にカテゴリをparent_idでインデックス付けすることによって機能します。次に、カテゴリごとに、category->childs を childs[category->id] に設定するだけで、ツリーが構築されます。

つまり、$tree はカテゴリ ツリーです。これには、sub_id=0 の項目の配列が含まれており、それ自体に子の配列が含まれており、それ自体が ...

print_r($tree) の出力:

stdClass Object
(
    [id] => 1
    [sub_id] => 0
    [childs] => Array
    (
        [0] => stdClass Object
            (
                [id] => 42
                [sub_id] => 1
                [childs] => Array
                    (
                        [0] => stdClass Object
                            (
                                [id] => 43
                                [sub_id] => 42
                            )

                    )

            )

    )

)

したがって、ここに最終的な関数があります:

function buildTree($items) {

    $childs = array();

    foreach($items as $item)
        $childs[$item->sub_id][] = $item;

    foreach($items as $item) if (isset($childs[$item->id]))
        $item->childs = $childs[$item->id];

    return $childs[0];
}

$tree = buildTree($items);
于 2013-03-27T14:51:19.553 に答える