【发布时间】:2014-12-25 05:38:50
【问题描述】:
我有一个具有这种结构的数组 $tree:
Array
(
[0] => Array
(
['fichier'] => 'test.xml'
['classes'] => Array
(
[0] => Array
(
['Id'] => '10'
['IdParent'] => 'L'
)
[1] => Array
(
['Id'] => '10-01'
['IdParent'] => '10'
)
...
)
)
[1] => Array
(
['fichier'] => 'test2.xml'
['classes'] => Array
(
[0] => Array
(
['Id'] => '10'
['IdParent'] => 'L'
)
[1] => Array
(
['Id'] => '10-02'
['IdParent'] => '10'
)
...
)
)
)
[2] => Array
(
...
)
...
)
这样的结构
L L ...
10 10
10-01 10-02
10-01-01 10-02-02
10-01-02 10-02-03
我尝试制作一个像这样的树视图:
L
-> 10
-> 10-01
-> 10-01-01
-> 10-01-02
-> 10-02
-> 10-02-02
-> 10-02-03
我写了一个递归函数:
function treeview($tree, $indiceTree, &$prec, $id = 'ICM'){
$indice = 0;
for ($i = ($indiceTree-sizeof($tree)); $i < sizeof($tree); $i++) {
for ($j = 0; $j < sizeof($tree[$i]['classes']); $j++) {
if($tree[$i]['classes'][$j]['IdParent']==$id) {
if (strpos($prec,$tree[$i]['classes'][$j]['Id']) == false) {
echo $tree[$i]['classes'][$j]['Id']; echo "<br><br>";
$prec .= ";".$tree[$i]['classes'][$j]['Id'];
break;
}
treeview($tree, $indiceTree+$indice,$prec, $tree[$i]['classes'][$j]['Id']);
break;
}
}
$indice++;
}
}
问题是这个功能永远不会停止。我的意思是显示结果很好,但仅在 PHP 超时时才显示: 致命错误:超过 60 秒的最大执行时间
初始数组 ($tree) 有 142 个元素,因此执行时间确实太长,无法在 Web 应用程序中使用。 完成数组后,函数似乎永远不会停止。 如果你能帮我完成这个功能。提前谢谢你
【问题讨论】: