gpt4 book ai didi

php - 如何使递归 TreeView 可折叠

转载 作者:太空宇宙 更新时间:2023-11-04 00:15:00 26 4
gpt4 key购买 nike

我有一个递归 TreeView ,它从数据库中提取所有信息,并且想了解如何使其可折叠。我尝试使用 Jquery 和 Javascript,但都没有任何效果。不确定是我的错误还是其他原因。

这是我的基本代码:

<body>
<?php
mysql_connect('localhost', 'root');
mysql_select_db('test');


$qry="SELECT * FROM treeview_items";
$result=mysql_query($qry);


$arrayCategories = array();

while($row = mysql_fetch_assoc($result)){
$arrayCategories[$row['id']] = array("parent_id" => $row['parent_id'], "name" =>
$row['title']);
}
//createTree($arrayCategories, 0);

function createTree($array, $currentParent, $currLevel = 0, $prevLevel = -1) {

foreach ($array as $categoryId => $category) {

if ($currentParent == $category['parent_id']) {

if ($currLevel > $prevLevel) echo " <ul> ";

if ($currLevel == $prevLevel) echo " </li> ";

echo '<li id="'.$categoryId.'" onclick=child(this.id);>
<span>'.$category['name'].'</span>';

if ($currLevel > $prevLevel) { $prevLevel = $currLevel; }

$currLevel++;

createTree ($array, $categoryId, $currLevel, $prevLevel);

$currLevel--;
}

}

if ($currLevel == $prevLevel) echo " </li> </ul> ";

}
?>
<div id="content" class="general-style1">
<?php
if(mysql_num_rows($result)!=0)
{
?>
<ul>
<li id="0" class="root"><span>Categories</span>
<?php createTree($arrayCategories, 0); ?>
</li>
</ul>
<?php
}
?>
</div>
</body>
</html>

感谢任何帮助!

最佳答案

我认为非常值得看看这种用于可折叠 TreeView 的纯 css 方法:http://www.thecssninja.com/css/css-tree-menu通过一些修改,它可以用于您可能想要使用的任何类型的 TreeView 。

关于php - 如何使递归 TreeView 可折叠,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11665976/

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