本文目录一览:
- 1、用php调数据库做树状显示
- 2、谁有详细php 下拉菜单代码?
- 3、PHP递归树形菜单
- 4、php如何分页显示树状结构数据?
- 5、在php后台中如何实现页面左侧常用的树状多级菜单呢?如果可以的说下原理并留下一个实例吧。谢谢了!
用php调数据库做树状显示
数据库设计的时候,通常的做法是用父ID来解决树状结构,也有二叉树等等
id pid category_name
然后,用递归就能实现,也有引用数组的方式
?php
/**
* 此方法由@Tonton 提供
*
* @date 2012-12-12
*/
function genTree5($items) {
foreach ($items as $item)
$items[$item['pid']]['son'][$item['id']] = $items[$item['id']];
return isset($items[0]['son']) ? $items[0]['son'] : array();
}
/**
* 将数据格式化成树形结构
* @author Xuefen.Tong
* @param array $items
* @return array
*/
function genTree9($items) {
$tree = array(); //格式化好的树
foreach ($items as $item)
if (isset($items[$item['pid']]))
$items[$item['pid']]['son'][] = $items[$item['id']];
else
$tree[] = $items[$item['id']];
return $tree;
}
$items = array(
1 = array('id' = 1, 'pid' = 0, 'name' = '江西省'),
2 = array('id' = 2, 'pid' = 0, 'name' = '黑龙江省'),
3 = array('id' = 3, 'pid' = 1, 'name' = '南昌市'),
4 = array('id' = 4, 'pid' = 2, 'name' = '哈尔滨市'),
5 = array('id' = 5, 'pid' = 2, 'name' = '鸡西市'),
6 = array('id' = 6, 'pid' = 4, 'name' = '香坊区'),
7 = array('id' = 7, 'pid' = 4, 'name' = '南岗区'),
8 = array('id' = 8, 'pid' = 6, 'name' = '和兴路'),
9 = array('id' = 9, 'pid' = 7, 'name' = '西大直街'),
10 = array('id' = 10, 'pid' = 8, 'name' = '东北林业大学'),
11 = array('id' = 11, 'pid' = 9, 'name' = '哈尔滨工业大学'),
12 = array('id' = 12, 'pid' = 8, 'name' = '哈尔滨师范大学'),
13 = array('id' = 13, 'pid' = 1, 'name' = '赣州市'),
14 = array('id' = 14, 'pid' = 13, 'name' = '赣县'),
15 = array('id' = 15, 'pid' = 13, 'name' = '于都县'),
16 = array('id' = 16, 'pid' = 14, 'name' = '茅店镇'),
17 = array('id' = 17, 'pid' = 14, 'name' = '大田乡'),
18 = array('id' = 18, 'pid' = 16, 'name' = '义源村'),
19 = array('id' = 19, 'pid' = 16, 'name' = '上坝村'),
);
echo "pre";
print_r(genTree5($items));
print_r(genTree9($items));
?
谁有详细php 下拉菜单代码?
这是我自己用的一段代码,你自己改一下,点一下一级文本框,它所属的文本框会收起或伸展。
SCRIPT language=javascript
!--
function menu_tree(meval)
{
var left_n=eval(meval);
if (left_n.style.display=="none")
{ eval(meval+".style.display='';"); }
else
{ eval(meval+".style.display='none';"); }
}
--
/SCRIPT
TABLE class=navi cellSpacing=1 align=center border=0
TBODY
TR
TH后台 新闻分类/TH/TR/TBODY/TABLEBR
table border=0 cellspacing=1 align=center class=form
tr
th colspan="2"添加分类/th
/tr
form action="" method="post"
tr
td colspan="2" align="center" height='30'
select name="fid"
option value="0"添加大类/option
?php
$query=$db-findall("shipin where fid=0");
while ($row=$db-fetch_array($query)){
$new_class_arr[$row[id]]=$row[name];
echo "option value=\"$row[id]\"$row[name]/option";
}
?
/select
input type="text" name="name" value=""
input type="submit" name="into_class" value="添加分类"/
/td
/form
/tr
/table
br
table border=0 cellspacing=1 align=center class=form
tr
th colspan="2"系统分类/th
/tr
?php
foreach ($new_class_arr as $id=$val){
?
tr
td onClick ="javascript:menu_tree('left?=$id ?');"
form action="" method="post"
IMG src="images/menu.gif" align=absMiddle border=0
input type="hidden" name="id" value="?php echo $id?"
input type="text" name="name" value="?php echo $val?"
input type="submit" name="update_class" value="更新"/
input type="button" value="删除" onclick="location.href='?del=?php echo $id?'"/
/form
/td
/tr
tr id=left?=$id ?
td
table
tbody
?php
$query_fid=$db-findall("shipin where fid=$id");
while ($row_fid=$db-fetch_array($query_fid)){
?
tr
td
form action="" method="post"
IMG src="images/menu.gif" align=absMiddle border=0
input type="hidden" name="id" value="?php echo $row_fid[id]?"
input type="text" name="name" value="?php echo $row_fid[name]?"
input type="submit" name="update_class" value="更新"/
input type="button" value="删除" onclick="location.href='?del=?php echo $row_fid[id]?'"/
/form
/td/tr
?php }?
/tbody
/table
/td
/tr
?php
}
?
/table
/BODY/HTML
PHP递归树形菜单
可以参考以下代码,但需要把你自己的数据库链接,表等改一下就可以了
html
head
link href='style.css' rel=stylesheet
meta http-equiv="Content-Type" content="text/html; charset=utf-8" /
script language="JavaScript" src="TreeMenu.js"/script
/head
body
?php
//基本变量设置
$GLOBALS["ID"] =1; //用来跟踪下拉菜单的ID号
$layer=1; //用来跟踪当前菜单的级数
//连接数据库
$Con=mysql_connect("localhost","root","1234");
mysql_select_db("wiki");
//提取一级菜单
$sql="SELECT * FROM wiki where pid=0";
$result=mysql_query($sql,$Con);
//如果一级菜单存在则开始菜单的显示
if(mysql_num_rows($result)0) ShowTreeMenu($Con,$result,$layer,$ID);
//=============================================
//显示树型菜单函数 ShowTreeMenu($con,$result,$layer)
//$con:数据库连接
//$result:需要显示的菜单记录集
//layer:需要显示的菜单的级数
//=============================================
function ShowTreeMenu($Con,$result,$layer)
{
//取得需要显示的菜单的项目数
$numrows=mysql_num_rows($result);
//开始显示菜单,每个子菜单都用一个表格来表示
echo "table cellpadding='0' cellspacing='0' border='0'";
for($rows=0;$rows$numrows;$rows++)
{
//将当前菜单项目的内容导入数组
$menu=mysql_fetch_array($result);
//提取菜单项目的子菜单记录集
$sql="select * from wiki where pid=$menu[cid]";
$result_sub=mysql_query($sql,$Con);
echo "tr";
//如果该菜单项目有子菜单,则添加JavaScript onClick语句
if(mysql_num_rows($result_sub)0)
{
echo "td width='20'img src='folder.gif' border='0'/td";
echo "td class='Menu' onClick='javascript:ShowMenu(Menu".$GLOBALS["ID"].");'";
}
else
{
echo "td width='20'img src='file.gif' border='0'/td";
echo "td class='Menu'";
}
//如果该菜单项目没有子菜单,并指定了超级连接地址,则指定为超级连接,
//否则只显示菜单名称
//if($menu[url]!="")
//echo "a href='$menu[cid]'$menu[name]/a";
//else
echo $menu['name'];
echo "
/td
/tr
";
//如果该菜单项目有子菜单,则显示子菜单
if(mysql_num_rows($result_sub)0)
{
//指定该子菜单的ID和style,以便和onClick语句相对应
echo "tr id=Menu".$GLOBALS["ID"]++." style='display:none'";
echo "td width='20' /td";
echo "td";
//将级数加1
$layer++;
//递归调用ShowTreeMenu()函数,生成子菜单
ShowTreeMenu($Con,$result_sub,$layer);
//子菜单处理完成,返回到递归的上一层,将级数减1
$layer--;
echo "/td/tr";
}
//继续显示下一个菜单项目
}
echo "/table";
}
?
/body
/html
php如何分页显示树状结构数据?
分页了还怎么显示树状?能显示 但是很难看 ,看不出效果了,我写后台菜单管理从来不分页,phpcmsV9 也没有分页 。我推荐使用 tree.class.php phpcmsV9 的一个扩展类文件,可以看看怎么使用。如图 我就是直接显示的:
在php后台中如何实现页面左侧常用的树状多级菜单呢?如果可以的说下原理并留下一个实例吧。谢谢了!
//'name'='标题','main_page'='左导航','r_nav'='默认主页'
$group_type_arr=array(
2=array('name'='企业管理','main_page'='admin_enterprise','r_nav'='admin_enterprise_open'),
4=array('name'='个人用户管理','main_page'='user_ctrl','r_nav'='admin_user_dat'),
5=array('name'='点评管理','main_page'='comment_ctrl','r_nav'='comment'),
7=array('name'='统计管理','main_page'='stats_ctrl','r_nav'='admin_product_business_count'),
8=array('name'='群组管理','main_page'='group_ctrl','r_nav'='useradmin'),
);
这是左侧第一级菜单,循环这个,在它里面可以直接加入二级菜单