计算机知识 - 计算机基础知识 - 电脑教程 - 电脑知识 - 电脑基础知识 加入收藏 | 设为首页 | 网站地图 | RSS
包罗万象网
您当前的位置:首页 > 网站建设 > php

PHP实现windows的树型菜单的方法

时间:2012-02-22 13:27:21  来源:网站建设  作者:Isolated

 以下是一个风格类似windows资源管理器的树型菜单

将下面的脚本包含到你的页面中

另外需要从资源管理器中截取一些gif图片,祥见脚本中的注释

菜单结构文件的格式为:

tree level|item text|item link|link target|last item in subtree

例如

.<b>Demo menu</b>|javascript: alert('This is the demo menu for TreeMenu 1.0');

<b>目录1</b>

…<b>子目录 1.1</b>

…item 1.1.1|javascript: alert('Item 1.1.1');

…item 1.1.2|javascript: alert('Item 1.1.1');

…item 1.2|javascript: alert('Item 1.2');

…item 1.3|javascript: alert('Item 1.3');

<b>子目录 2</b>

…item 2.1|javascript: alert('Item 2.1');

…item 2.2|javascript: alert('Item 2.2');

…<b>子目录 2.3</b>

…item 2.3.1|javascript: alert('Item 2.3.1');

…item 2.3.2|javascript: alert('Item 2.3.2');

<?php

// file:tremenu.inc

// PHP TreeMenu

/////////////////

// 初始化 //

/////////////////

$treefile = "demomenu.txt";//设置有菜单结构的文件

if(isset($PATH_INFO))

$script = $PATH_INFO;

else

$script = $SCRIPT_NAME;

//以下图片可截取windows资源管理器中的相应位置的图

$img_expand = "tree_expand.gif";//形如资源管理器中可扩展节点+

$img_collapse = "tree_collapse.gif";//形如资源管理器中已扩展节点-

$img_line = "tree_vertline.gif";//形如|

$img_split = "tree_split.gif";//形如|-

$img_end = "tree_end.gif";//形如L

$img_leaf = "tree_leaf.gif";//形如o

$img_spc = "tree_space.gif";//空白图

//以下是菜单处理脚本

$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;

}

来顶一下
返回首页
返回首页
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表
推荐资讯
相关文章
栏目更新
栏目热门