情况如下: 我有一个需要从数据库动态创建的菜单。 菜单层次结构由表中的“父”列确定(每个条目有一个父项,如果它只是父项,则为NULL)
问题在于我无法想到我将如何动态地执行此操作,因为我的下拉菜单需要正确的<ul><li><ul><li>
结构。
这要求我在父页面的foreach中有我的'foreach'子页面?
如果这是有道理的,是否有解决方案?
仅供参考:我正在使用的数组返回:
array(31) {
[0]=> array(5)
{ ["id"]=> string(2) "31" ["title"]=> string(4) "Home" ["linkable"]=> string(1) "1" ["parent"]=> NULL ["override"]=> string(1) " " }
[1]=> array(5)
{ ["id"]=> string(2) "30" ["title"]=> string(11) "Shop Online" ["linkable"]=> string(1) "1" ["parent"]=> string(2) "31" ["override"]=> string(4) "shop" }
and on and on.
答案 0 :(得分:2)
你需要编写一个递归函数来执行此操作并让它自己调用。我没有测试过这个,但我认为它应该让你开始。我不赞同这个函数的效率,因为它遍历数组中的每个项目并进行比较,即使你每次运行只需要一两个项目(可能)。
PHP:
$arr = array(...);
function output_lis($parentID = NULL){
global $arr;
$stack = array(); //create a stack for our <li>'s
foreach($arr as $a){
$str = '';
//if the item's parent matches the parentID we're outputting...
if($a['parent']===$parentID){
$str.='<li>'.$a['title'];
//Pass this item's ID to the function as a parent,
//and it will output the children
$subStr = output_lis($a['id']);
if($subStr){
$str.='<ul>'.$subStr.'</ul>';
}
$str.='</li>';
$stack[] = $str;
}
}
//If we have <li>'s return a string
if(count($stack)>0){
return join("\n",$stack);
}
//If no <li>'s in the stack, return false
return false;
}
然后在您的页面上输出。类似的东西:
<ul>
<?php echo output_lis(); ?>
</ul>
这是我的示例数组:
$arr = array(
array('title'=>'home','parent'=>NULL,'id'=>1),
array('title'=>'sub1','parent'=>1,'id'=>2),
array('title'=>'sub2','parent'=>1,'id'=>3),
array('title'=>'about us','parent'=>NULL,'id'=>4),
array('title'=>'sub3','parent'=>4,'id'=>5),
array('title'=>'sub4','parent'=>4,'id'=>6),
);
答案 1 :(得分:0)
不需要递归。
$parents = array();
$noparents = array();
foreach ($results as $ar) {
if ( $ar['parent'] != NULL ) {
$parents[$ar['parent']] = array();
array_push($parents[$ar['parent']], $ar['title']);
} else {
array_push($noparents, $ar['title']);
}
}
现在,您拥有属于以父命名的数组中列出的父级的所有链接。您的其他链接位于单独的阵列中。如果你愿意,你可以加入他们。
根据您的应用程序进行扩展。