我正在尝试创建一个动态导航列表,其中包含列表
中每个项目的子列表我有1个数组,包含12个父类别值,是一个简单的1维数组。
我正在循环使用foreach循环来制作无序列表
我遇到的问题是我有一个子类别数组,它是一个多维数组,我需要为每个属于父类别的子类别创建一个嵌套列表。
<?php
//mysql query to get the parent categories
$query = "SELECT `parent` FROM `categories` GROUP BY `parent`";
$result = mysql_query($query);
while ($row = mysql_fetch_assoc($result)) {
$cat[] = $row['parent']; //define the parent categories as a variable
}?>
<div id="navigation">
<ul>
<li><a href="http://localhost/softwarereviews.com">Home</a></li>
<?php
//loop through the parent categories
foreach ($cat as $parent) {
//another query to get the child categories that belong to each parent category
$query = "SELECT * FROM `categories` WHERE `parent` = '$parent'";
$result = mysql_query($query)
or die(mysql_error());
while ($row = mysql_fetch_assoc($result)) {
//need 2 results so create a multi - dimensional array
$children[] = array($row['name'] => $row['cat_label']);
}?>
<li><?php echo $parent; ?></li>
<ul>
<?php foreach ($children as $key => $value) { ?>
<?php foreach ($value as $key => $value) { ?>
<li><a href="<?php echo $value;?>"><?php echo $key;?></a><li>
<?php }
}?>
</ul>
<?php }?>
</ul>
</div>
目前发生的情况是每个类别的子列表会不断追加先前的列表结果,从而使每个子列表的结果越来越大。
答案 0 :(得分:2)
在$children
循环
foreach
foreach ($cat as $parent) {
$children = array();
...
答案 1 :(得分:0)
如果您有简单数组
foreach($rows as $row){
$row[0];
$row['myKey'];
}
如果您有多维数组,但此数组可以使用唯一行,请执行此操作
// foreach((condition)? true:false as child){ ... }
foreach((is_array($rows[0]))? $rows : array('0'=>$rows) as $row){
$row[0];
$row['myKey'];
}