私はこのSQLテーブルを持っています
phpのように返すには?
Root1
- SubCat 1
-- SubSubCat 1
- SubCat 2
Root2
これを見つけましたが、必要な形で返すことができません。ただし、スクリプトは、最初はサブとして、次にルートとして、すべてのカテゴリを表示します。
作り方は?
これは仕事をします:
$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);