我有一系列用户,每个用户都可以有父母:
array(6) {
guest => NULL
moderator => NULL
member => array(1) [ //username
0 => "guest" (5) //parent
]
user => array(1) [
0 => "member" (6)
]
admin => array(1) [
0 => "moderator" (9)
]
}
我想从这些数据中创建树视图。结果应如下所示:http ://www.phorum.org/phorum5/file.php/62/3237/treeview_lightweight_admin_screenshot.jpg
结果将是:
- guest
- member
- user
- moderator
- admin
编辑:
我尝试编写树生成器,但我不知道如何使用递归。
private function generateTree($node)
{
$return = array();
if(is_array($node))
{
foreach($node as $user => $parents)
{
if(is_null($parents))
{
$return[$user] = null;
}
if(is_array($parents))
{
foreach($parents as $parent)
{
if(array_key_exists($parent, $return))
{
$return[$parent] = $user;
}
else
{
dump($user, $parent);
}
}
}
}
}
return $return;
}
返回:
array(2) {
guest => "member" (6)
moderator => "admin" (5)
}
剩下:
user => array(1) [
0 => "member" (6)
]