技术开发 频道

PHP实例:用PHP实现windows风格的树型菜单

以下是菜单处理脚本
<? $maxlevel=0; $cnt=0; $fd = fopen($treefile, "r"); if ($fd==0) die("treemenu.inc : Unable to open file ".$treefile); while ($buffer = fgets($fd, 4096)) { $tree[$cnt][0]=strspn($buffer,"."); $tmp=rtrim(substr($buffer,$tree[$cnt][0])); $node=explode("",$tmp); $tree[$cnt][1]=$node[0]; $tree[$cnt][2]=$node[1]; $tree[$cnt][3]=$node[2]; $tree[$cnt][4]=0; if ($tree[$cnt][0] > $maxlevel) $maxlevel=$tree[$cnt][0]; $cnt++; } fclose($fd); for ($i=0; $i<count($tree); $i++) { $expand[$i]=0; $visible[$i]=0; $levels[$i]=0; } if ($p!="") $explevels = explode("",$p); $i=0; while($i<count($explevels)) { $expand[$explevels[$i]]=1; $i++; } $lastlevel=$maxlevel; for ($i=count($tree)-1; $i>=0; $i--) { if ( $tree[$i][0] < $lastlevel ) for ($j=$tree[$i][0]+1; $j <= $maxlevel; $j++) $levels[$j]=0; if ( $levels[$tree[$i][0]]==0 ) { $levels[$tree[$i][0]]=1; $tree[$i][4]=1; } else $tree[$i][4]=0; $lastlevel=$tree[$i][0]; } for ($i=0; $i < count($tree); $i++) if ($tree[$i][0]==1) $visible[$i]=1; for ($i=0; $i < count($explevels); $i++) { $n=$explevels[$i]; if ( ($visible[$n]==1) && ($expand[$n]==1) ) { $j=$n+1; while ( $tree[$j][0] > $tree[$n][0] ) { if ($tree[$j][0]==$tree[$n][0]+1) $visible[$j]=1; $j++; } } } for ($i=0; $i<$maxlevel; $i++) $levels[$i]=1; $maxlevel++;
0
相关文章