gpt4 book ai didi

PHP MySQL 多维数组 - 下拉菜单

转载 作者:行者123 更新时间:2023-11-29 08:12:27 24 4
gpt4 key购买 nike

我想从 mysql 查询创建下拉菜单,但我在处理子项目时遇到了问题。

我的基本表:

NavigationID  ParentID  Name       Url
1 1 Home home
2 2 About about
3 3 Products products
4 3 Category1 #
5 3 Category2 #
6 4 Product1 #
7 5 Product2 #

我的简单 MySQL 查询并添加到数组:

class Navigation{
private $data;

public function __construct($par){
if(is_array($par))
$this->data = $par;
}

public function __toString(){
return '<li><a href="'.$this->data['Url'].'">'.$this->data['Name'].'</a></li>';
}
}

$query = mysql_query("SELECT * FROM Navigation n") or die(mysql_error());
$num = mysql_num_rows($query);
$menuitems = array();

while($row = mysql_fetch_assoc($query)){
$menuitems[] = new Navigation($row);
}

echo '<div id="nav"><ul>';
foreach($menuitems as $item){
echo $item;
}
echo '</ul></div>';

结果是:

<div id="nav"><ul>
<li><a href="home">Home</a></li>
<li><a href="about">About</a></li>
<li><a href="products">Products</a></li>
<li><a href="#">Category1</a></li>
<li><a href="#">Category2</a></li>
<li><a href="#">Product1</a></li>
<li><a href="#">Product2</a></li>
</ul></div>

但我真正想要的是:

<div id="nav"><ul>
<li><a href="home">Home</a></li>
<li><a href="about">About</a></li>
<li><a href="products">Products</a>
<ul>
<li><a href="#">Category1</a>
<ul>
<li><a href="#">Product1</a></li>
</ul>
</li>
<li><a href="#">Category2</a>
<ul>
<li><a href="#">Product2</a></li>
</ul>
</li>
</ul>
</li>
</ul></div>

我怎样才能达到这个结果?我尝试过很多其他例子,但似乎没有一个对我有帮助。也许我没有在寻找正确的东西。

最佳答案

为什么要让它变得复杂,这可以通过一个非常简单的递归函数来完成。

这是我在本地计算机上所做的。我有连接参数,然后调用一个函数

bulit_tree(0);
  • 在此函数中,它将检查参数是否为 0,然后选择全部id 和parentid 相同的项目。
  • 然后循环并使用递归函数生成子树。
  • 需要确保 $con 在函数内可访问。

    $con = mysql_connect("localhost","testuser","testpass");

    $db_selected = mysql_select_db('testdb', $con);
    if (!$db_selected) {
    die ('Can\'t use testdb : ' . mysql_error());
    }

    bulit_tree(0);

    function bulit_tree($pid=0){
    global $con ;
    if($pid == 0 ){
    $qry = "select * from Navigation where NavigationID = ParentID";
    $q = mysql_query($qry,$con);
    if(mysql_num_rows($q) > 0 ){
    echo '<ul>';
    while($row = mysql_fetch_assoc($q)){
    echo '<li><a href="'.$row["Url"].'">'.$row["Name"].'</a>';
    bulit_tree($row["NavigationID"]);
    echo '</li>';
    }
    echo '</ul>';
    }
    }else{
    $qry = "select * from Navigation where ParentID = ".$pid." AND NavigationID <> ".$pid;
    $q = mysql_query($qry,$con);
    if(mysql_num_rows($q) > 0 ){
    echo '<ul>';
    while($row = mysql_fetch_assoc($q)){
    echo '<li><a href="'.$row["Url"].'">'.$row["Name"].'</a>';
    bulit_tree($row["NavigationID"]);
    echo '</li>';
    }
    echo '</ul>';
    }
    }
    }

关于PHP MySQL 多维数组 - 下拉菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21306338/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com