php创建无限级树型菜单以及三级联动菜单

http://www.php.cn/php-weizijiaocheng-373500.html

 这篇文章主要介绍了php创建无限级树型菜单 ,主要使用的是递归函数,感兴趣的小伙伴们可以参考一下

 

写递归函数,可考虑缓存,定义一些静态变量来存上一次运行的结果,多程序运行效率很有帮助.。
大概步骤如下
step1:到数据库取数据,放到一个数组,
step2:把数据转化为一个树型状的数组,
step3:把这个树型状的数组转为html代码。
也可以将第二步和第三步合为一步。
详细如下:
1、数据库设计:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

CREATE TABLE `bg_cate` (

`cate_Id` int(30) unsigned NOT NULL AUTO_INCREMENT,

`cate_ParentId` int(30) unsigned DEFAULT '0',

`cate_Name` varchar(100) NOT NULL,

`cate_Intro` varchar(500) DEFAULT NULL,

`cate_Order` int(30) unsigned DEFAULT '0',

`cate_Icon` varchar(100) DEFAULT NULL,

PRIMARY KEY (`cate_Id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=34 ;

--

-- 导出表中的数据 `bg_cate`

--

INSERT INTO `bg_cate` (`cate_Id`, `cate_ParentId`, `cate_Name`, `cate_Intro`, `cate_Order`, `cate_Icon`) VALUES

(4, 0, '往事如风', '记录往事', 0, 'icons/6.gif'),

(5, 0, '水煮三国', '品位三国智慧', 0, 'icons/3.gif'),

(2, 0, '技术学习', '平时学习的一些笔记,欢迎批评指正。', 0, 'icons/18.gif'),

(3, 0, '生活点滴', '记录生活点滴', 0, 'icons/2.gif'),

(6, 0, '栀子花开', '青春无限', 0, 'icons/8.gif'),

(7, 0, '假日休闲', '悠闲、自在', 0, 'icons/24.gif'),

(8, 2, 'html', 'html学习', 0, 'icons/1.gif'),

(9, 2, 'css', 'css学习', 0, 'icons/1.gif'),

(10, 2, 'php', 'php学习', 0, 'icons/18.gif'),

(11, 10, 'php基础知识', 'php基础知识', 0, 'icons/1.gif'),

(12, 10, 'oop', 'oop', 0, 'icons/1.gif'),

(13, 10, 'php安全', '讲述php安全', 0, 'icons/1.gif'),

(14, 10, 'seagull framework', 'seagull framework', 0, 'icons/1.gif'),

(15, 2, 'javascript', 'javascript学习', 0, 'icons/1.gif'),

(16, 2, '设计模式', NULL, 0, 'icons/1.gif'),

(17, 2, '软件工程', '软件工程学习', 0, 'icons/1.gif'),

(18, 3, '厦门生活', '厦门生活', 0, 'icons/8.gif'),

(19, 3, '大学生活', '大学生活', 0, 'icons/8.gif'),

(20, 3, '童年生活', '童年生活', 0, 'icons/15.gif'),

(21, 19, '学习', '学习', 0, 'icons/1.gif'),

(22, 19, '运动', '运动', 0, 'icons/16.gif'),

(23, 19, '旅游', '旅游', 0, 'icons/24.gif'),

(24, 22, '排球', '排球', 0, 'icons/9.gif'),

(25, 22, '篮球', '篮球', 0, 'icons/9.gif'),

(26, 22, '羽毛球', '羽毛球', 0, 'icons/9.gif'),

(27, 22, '乒乓球', '乒乓球', 0, 'icons/9.gif');

2、到数据库取数据,放到数组:

1

2

3

4

5

6

7

require_once './classes/MyDB.php';

$con = MyDB::singleton();

$sql = <<<SQL

 select * from bg_cate cate

SQL;

$data = $con->getAll($sql);

//print_r($data);

数据库操作我用的是pear类库,最后的$data的数据格式如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

Array

(

 [0] => Array

 (

 [cate_Id] => 4

 [cate_ParentId] => 0

 [cate_Name] => 往事如风

 [cate_Intro] => 记录往事

 [cate_Order] => 0

 [cate_Icon] => icons/6.gif

 )

 [1] => Array

 (

 [cate_Id] => 5

 [cate_ParentId] => 0

 [cate_Name] => 水煮三国

 [cate_Intro] => 品位三国智慧

 [cate_Order] => 0

 [cate_Icon] => icons/3.gif

 )

3、把上一步的数据转为树型状的数组代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

function getTree($data, $pId)

{

$tree = '';

foreach($data as $k => $v)

{

 if($v['cate_ParentId'] == $pId)

 { //父亲找到儿子

 $v['cate_ParentId'] = getTree($data, $v['cate_Id']);

 $tree[] = $v;

 //unset($data[$k]);

 }

}

return $tree;

}

$tree = getTree($data, 0);

最后输出$tree的数据格式为:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

Array

(

 [0] => Array

 (

 [cate_Id] => 4

 [cate_ParentId] =>

 [cate_Name] => 往事如风

 [cate_Intro] => 记录往事

 [cate_Order] => 0

 [cate_Icon] => icons/6.gif

 )

 [1] => Array

 (

 [cate_Id] => 5

 [cate_ParentId] =>

 [cate_Name] => 水煮三国

 [cate_Intro] => 品位三国智慧

 [cate_Order] => 0

 [cate_Icon] => icons/3.gif

 )

 [2] => Array

 (

 [cate_Id] => 2

 [cate_ParentId] => Array

 (

  [0] => Array

  (

  [cate_Id] => 8

  [cate_ParentId] =>

  [cate_Name] => html

  [cate_Intro] => html学习

  [cate_Order] => 0

  [cate_Icon] => icons/1.gif

  )

4、把树型状数组转为html代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

function procHtml($tree)

{

$html = '';

foreach($tree as $t)

{

 if($t['cate_ParentId'] == '')

 {

 $html .= "<li>{$t['cate_Name']}</li>";

 }

 else

 {

 $html .= "<li>".$t['cate_Name'];

 $html .= procHtml($t['cate_ParentId']);

 $html = $html."</li>";

 }

}

return $html ? '<ul>'.$html.'</ul>' : $html ;

}

echo procHtml($tree);

输出的html的代码格式为:

<ul>

<li>往事如风</li>

<li>水煮三国</li>

<li>技术学习

 <ul>

 <li>html</li>

 <li>css</li>

 <li>php

 <ul>

 <li>php基础知识</li>

 <li>oop</li>

 <li>php安全</li>

5、也可以把第3和第4步的代码合在一起,代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

function getTree($data, $pId)

{

$html = '';

foreach($data as $k => $v)

{

 if($v['cate_ParentId'] == $pId)

 { //父亲找到儿子

 $html .= "<li>".$v['cate_Name'];

 $html .= getTree($data, $v['cate_Id']);

 $html = $html."</li>";

 }

}

return $html ? '<ul>'.$html.'</ul>' : $html ;

}

echo getTree($data, 0);

6、最后再加点css样式,效果如下:

整个过程思路很清晰,非常适合第一次创建无限级树型的朋友学习,希望大家都有所收获。

以下是利用php做的三级联动菜单

数据库结构

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

-- 表的结构 `bigclass`

--

CREATE TABLE `bigclass` (

`bigclassid` int(11) NOT NULL auto_increment,

`bigclassname` varchar(200) collate utf8_unicode_ci NOT NULL,

`sort` int(11) NOT NULL,

`suoshu` int(1) NOT NULL,

PRIMARY KEY (`bigclassid`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=19 ;

-- 表的结构 `smallclass`

--

CREATE TABLE `smallclass` (

`smallclassid` int(11) NOT NULL auto_increment,

`smallclassname` varchar(200) collate utf8_unicode_ci NOT NULL,

`bigclassid` int(11) NOT NULL,

`sort` int(11) NOT NULL,

PRIMARY KEY (`smallclassid`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=7 ;

-- 表的结构 `minclass`

--

CREATE TABLE `minclass` (

`minclassid` int(10) NOT NULL auto_increment,

`minclassname` varchar(200) NOT NULL,

`bigclassid` int(10) NOT NULL,

`smallclassid` int(10) NOT NULL,

`sort` int(10) NOT NULL,

PRIMARY KEY (`minclassid`)

) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;

代码如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

<script language = "JavaScript">

var onecount;

onecount=0;

subcat = new Array();

<?

//类别选择

mysql_select_db($database_lr, $lr);

$sql = "select * from smallclass order by sort";

$result = mysql_query( $sql );

$count = 0;

while($res = mysql_fetch_row($result)){

?>

subcat[<?=$count?>] = new Array("<?=$res[1]?>","<?=$res[4]?>","<?=$res[0]?>");

<?

$count++;

}

?>

onecount=<?php echo $count?>

//联动函数

function changelocation(bigclassid)

{

document.myform.smallclassid.length = 0;

var bigclassid=bigclassid;

var i;

document.myform.smallclassid.options[0] = new Option('请选择二级分类','');

for (i=0;i < onecount; i++)

{

if (subcat[i][1] == bigclassid)

{

document.myform.smallclassid.options[document.myform.smallclassid.length] = new Option(subcat[i][0], subcat[i][2]);

}

}

}

</script>

<?php

mysql_select_db($database_lr, $lr);

$sql2 = "select * from minclass order by sort";

$result2 = mysql_query( $sql2 );

$count2 = 0;

?>

<script language = "JavaScript">

//如果这个数组中含有双引号则不能使用。即二级和三级类不能含有双引号

var onecount2;

onecount2=0;

subcat2 = new Array();

<?php

$count2 = 0;

while($res2 = mysql_fetch_row($result2)){

?>

subcat2[<?php echo $count2?>] = new Array("<?php echo $res2[1]?>","<?php echo $res2[3]?>","<?php echo $res2[0]?>");

<?php

$count2++;

}

?>

onecount2=<?php echo $count2?>;

function changelocation2(smallclassid)

{

document.myform.minclassid.length = 0;

var smallclassid=smallclassid;

var j;

document.myform.minclassid.options[0] = new Option('请选择三级分类','');

for (j=0;j < onecount2; j++)

{

if (subcat2[j][1] == smallclassid)

{

document.myform.minclassid.options[document.myform.minclassid.length] = new Option(subcat2[j][0], subcat2[j][2]);

}

}

}

</script>

<select name="bigclassid" onChange="changelocation(document.myform.bigclassid.options[document.myform.bigclassid.selectedIndex].value)" size="1">

<option selected value="">请指定一级分类</option>

<?

$sql = "select * from bigclass order by sort";

$result = mysql_query( $sql );

while($res = mysql_fetch_row($result)){

?>

<option value="<? echo $res[0]; ?>"><? echo $res[1]?></option>

<? } ?>

</select>

<select name="smallclassid" onChange="changelocation2(document.myform.smallclassid.options[document.myform.smallclassid.selectedIndex].value)" size="1">

<option selected value="">请指定二级分类</option>

</select>

<select name="minclassid" size="1">

<option selected value="">==所有三级分类==</option>

</select>

以上就是php创建无限级树型菜单以及三级联动菜单的详细内容,更多请关注php中文网其它相关文章!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/399565.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle数据库用脚本运行SQL语句

1. 在同一个目录下创建 runBatch.bat sqlplus sys/sangfororcl as sysdba sql.txtpausesql.txt 要执行的SQL语句 2. 双击runBatch.bat转载于:https://www.cnblogs.com/ddmiao/p/3654227.html

使用Docker镜像和仓库

为什么80%的码农都做不了架构师&#xff1f;>>> Docker镜像 由文件系统叠加而成最底端第一层是引导文件系统bootfs&#xff0c;类似grub镜像第二层是root文件系统rootfs列出镜像 huangyiHP ~ % sudo docker images REPOSITORY TAG IMAGE …

ip_forward

Linux系统缺省并没有打开IP转发功能&#xff0c;要确认IP转发功能的状态。可以查看/proc文件系统&#xff0c;使用下面命令&#xff1a; cat /proc/sys/net/ipv4/ip_forward如果上述文件中的值为0,说明禁止进行IP转发&#xff0c;如果是1,则说明IP转发功能已经打开。要想打开I…

C++primer plus第六版课后编程题答案8.3(正解)

在百度知道里面得到了正确的答案 http://zhidao.baidu.com/question/198940026560129285.html?quesup2&oldq1 #include<iostream> #include <string>//出问题时&#xff0c;使用的是cstring,但换成string一样出问题 using namespace std; struct stringy{char…

WordPress后台删除不需要的侧边栏菜单

https://www.ludou.org/remove-admin-menu-in-wordpress.html function remove_submenu() {// 删除"设置"下面的子菜单"隐私"remove_submenu_page( options-general.php, options-privacy.php );// 删除"外观"下面的子菜单"编辑"remov…

CSS 实例

CSS 实例 CSS背景 设置页面的背景颜色 设置不同元素的背景颜色 设置一个图像作为页面的背景 错误的的背景图片 如何在水平方向重复背景图像 如何定位背景图像 一个固定的背景图片&#xff08;这个图片不会随页面的其余部分滚动&#xff09; 在一个声明的所有背景属性 高级的背景…

通过ajax提交到url路由

$regBoxform.find(button).on(click, function(){/*通过ajax提交请求*/$.ajax({type:post, /*用post 方式提交*/url:/user/register, /*提交到api的指定路由路径*/dataType: json,data:{username: $regBoxform.find([name"username"]).val(),password: $regBoxform.f…

wordpress发布文章时右侧边栏选择作者的功能代码

因为本网络营销博客现在有了两个作者&#xff0c;在后台发布文章时&#xff0c;希望可以选择作者&#xff08;以前仅是一个管理员&#xff09;。通过在网上查找资料&#xff0c;并进行实践成功。特分享如下。 一 在当前使用主题目录下的functions.php中添加以下php代码&#x…

查找邮件日志

#查找收件人的邮件get-messagetrackinglog -start "10/08/2015 17:00" -end "10/08/2015 21:00" -recipients "l1xin.com" #查找发件人的邮件get-messagetrackinglog -start "10/08/2015 17:00" -end "10/12/2015 17:00" -s…

c# webbrowser  获取用户选中文字

c# webbrowser 获取用户选中文字 原文:c# webbrowser 获取用户选中文字最近一直被一个问题困扰&#xff0c;有一个文本框&#xff0c;一个webbrowser控件&#xff0c;一个上下文菜单&#xff0c; 用户用鼠标左键选中文字&#xff0c;右键点击搜索&#xff0c;就把选中的文字赋…

修改节点的属性 节点默认不允许修改

xml的节点默认是不允许修改的&#xff0c;本文也就不做处理了 XmlDocument xmlDoc new XmlDocument(); xmlDoc.Load(xmlPath); XmlElement element (XmlElement)xmlDoc.SelectSingleNode("BookStore/NewBook"); element.SetAttribute("Name", "Zhan…

敏捷现状10周年调查

敏捷现状第10届调查 已于2015年10月2号对外开放。本次调查探讨了全球范围内敏捷实施的现状。\\\ [敏捷现状]报告给出了敏捷发展趋势&#xff0c;最佳实践和成功向敏捷转型获得的经验教训等方面的洞见&#xff0c;并且这些都是软件人才的真知灼见。该报告已然成为全球范围内规模…

解决EF 4.0 中数据缓存机制

EF4.0默认开启缓存机制&#xff0c;如果想要禁用缓存机制的话&#xff0c;则须加上一句话&#xff1a;_db.CreateObjectSet().MergeOption MergeOption.OverwriteChanges; public IQueryable<T> LoadEntities(Func<T, bool> whereLambda){try{var set _db.Create…

cannot be deleted directly via the port API: has device owner network:floatingip

cannot be deleted directly via the port API: has device owner network:floatingip posted on 2015-10-13 19:26 秦瑞It行程实录 阅读(...) 评论(...) 编辑 收藏 转载于:https://www.cnblogs.com/ruiy/p/4875605.html

170. Two Sum III - Data structure design【easy】

170. Two Sum III - Data structure design【easy】 Design and implement a TwoSum class. It should support the following operations:add and find. add - Add the number to an internal data structure.find - Find if there exists any pair of numbers which sum is e…

paip.提升效率---提升绑定层次--form绑定取代field绑定

paip.提升效率---提升绑定层次--form绑定取代field绑定 编辑form中,常常需要,绑定一个对象到个form.. 传统上要绑定field开始...降低效率..jsp>>>也是绑定field开始...asp.net也是,,,.net winform ,c 也是...从理论上说,Jsp把对象绑定到个form不好弄,只能输出js来客…

c# params 工作原理。

2019独角兽企业重金招聘Python工程师标准>>> 高级语言之所以成为高级语言&#xff0c;编译器付出了很多。params在给我们带来方便的同时&#xff0c;编译器也是贡献不少。 实例代码&#xff1a; using System; public class Test { public static void Main(){ C…

这7个在线工具,帮助您快速开发WordPress主题

由于WordPress遵从GPL协议&#xff0c;这个协议规定WordPress可以免费用于商业用途。这样做一个网站的成本就比较低。相对应的开发WordPress主题的需求就多起来了。结合笔者多年开发WordPress主题的经验&#xff0c;熟练使用下面一些免费的工具&#xff0c;在开发WordPress主题…

参数依赖查找(ADL,Argument-dependent lookup)

参数依赖查找&#xff08;Argument-dependent lookup&#xff09;&#xff0c;又称 ADL 或 Koenig 查找&#xff0c;是一组于函数调用表达式查找非限定函数名的规则&#xff0c;包含对重载运算符的隐式函数调用。在通常非限定名称查找所考虑的作用域和命名空间之外&#xff0c;…

让你的WordPress主题支持自定义菜单

WordPress 3以后的版本已经支持自定义菜单功能&#xff0c;如果你的主题还不能支持这个功能话&#xff0c;我敢说你的主题Out啦&#xff0c;是不是想再In进来&#xff1f;那就认真继续阅读&#xff0c;让你的WordPress主题支持自定义菜单功能。 啦&#xff0c;是不是想再In进来…