php如何循环通过多维数组

时间:2011-09-08 17:24:08

标签: php foreach

我正在尝试创建一个动态导航列表,其中包含列表

中每个项目的子列表

我有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>

目前发生的情况是每个类别的子列表会不断追加先前的列表结果,从而使每个子列表的结果越来越大。

2 个答案:

答案 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'];
}