php创建无限级树型菜单以及三级联动菜单-程序员宅基地

技术标签: 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中文网其它相关文章!

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/james_laughing/article/details/91351955

智能推荐

【毫米波雷达】毫米波雷达接收发射信号matlab仿真_毫米波雷达仿真-程序员宅基地

文章浏览阅读872次,点赞22次,收藏26次。毫米波雷达是一种利用毫米波段电磁波来探测目标的雷达系统。它具有体积小、重量轻、功耗低、分辨率高、抗干扰能力强等优点,广泛应用于汽车、航空、航天、军事等领域。毫米波雷达的工作原理是:雷达发射机发射毫米波电磁波,电磁波遇到目标后反射,反射波被雷达接收机接收,并根据反射波的强度、频率和相位等信息来确定目标的位置、速度和姿态。毫米波雷达的接收发射信号主要包括以下几个步骤:发射信号毫米波雷达发射机产生毫米波电磁波,并通过天线发射出去。发射信号的频率、功率和波形等参数由雷达系统的设计要求决定。信号传播。_毫米波雷达仿真

matlab for,while,break和continue循环和循环控制_matlab设计问题if,while,for都包含的例题-程序员宅基地

文章浏览阅读6.4k次,点赞6次,收藏8次。for循环循环特定的次数,用end表示循环快结束。示例如下:注意n可以从1取到10,总共循环10次。while循环只要条件为真,就一直循环,用end表示循环快结束。示例如下:该程序中,设置n初值为10,然后进入while循环中。m为产生不大于n的一个随机数,当产生的随机数m和n相等时,退出循环。否则把n加1,再次循环。运行结果如下:if end条件控制if后面要和一个布尔表达式,后面再跟一个或者多个语句分割,就是一个if..end语句。运行如下:i_matlab设计问题if,while,for都包含的例题

奇舞学院JS01—如何写好原生JS_原生js怎么写-程序员宅基地

文章浏览阅读159次。1、交通灯实例&lt;!DOCTYPE html&gt;&lt;html&gt;&lt;head&gt; &lt;title&gt;js04-1&lt;/title&gt; &lt;meta charset="utf-8"&gt; &lt;link rel="stylesheet" type="text/css" href=&qu_原生js怎么写

Call Stack (most recent call first): /opt/ros/melodic/share/catkin/cmake/all.cmake:208 (safe_execu-程序员宅基地

文章浏览阅读3.4k次。CMake Error at /opt/ros/melodic/share/catkin/cmake/safe_execute_process.cmake:11 (message): execute_process(/usr/bin/python "/tmp/QtCreator-XzPzFL/qtc-cmake-iCElsmaa/catkin_generated/generate_cached_setup.py") returned error code 1Call Stack (most r_call stack (most recent call first):

模型提取-程序员宅基地

文章浏览阅读8.6k次,点赞4次,收藏19次。3D游戏模型提取、导入、导出教程这个是我的第二个教程,这个教程的主要内容是教大家如何提取3D游戏里的模型,因为有一些3D游戏里面的模型非常精致,例如有一些人物模型或者场景模型。这样大大方便了模型的制作过程。希望这个教程能对大家有用。一,下载安装 1、下载3D游戏模型提取软件,下载地址:http://pan.baidu.co_模型提取

【避免if else标准写法】阿里P7级别(年薪40w-70w)是如何避免用if else写代码_阿里规范尽量不要else if-程序员宅基地

文章浏览阅读773次,点赞16次,收藏7次。不会吧还有人用if else和switch case?三目运算符?不会吧? 不会吧?大佬都是全都不用的!以JAVA为例条件判断语句的四种写法,茴字的四种写法大家不会不知道吧1.正常人写法: private static String MAN = "man"; private static String WOMAN = "woman"; @Data static class Person{ private String gender; p_阿里规范尽量不要else if

随便推点

[arcgis插件]尖锐角检查/批量处理工具-GIS程序猿_arcgis如何查尖锐角-程序员宅基地

文章浏览阅读459次。2、设置合并优先级。选择字段,设置优先级。无需优先级,可以吧文字清空,则会根据与地块有相同信息字段的值来合并。[arcgis插件]尖锐角检查/批量处理工具,支持arcgis10.2-10.8版本。7、仅仅检查选中的地块:先选中地块再执行流程。5、处理流程设置:1 处理,2 切割,3 合并。6、顺便检查选择检查狭长面、自相交、重复节点。4、存在尖锐角并且面积小于这个面积阈值,则无需切割,直接合并。可以选择shp数据、GDB或者MDB的矢量面图层。年度变更,又是尖锐角,死磕尖锐角,就不信搞不定它。_arcgis如何查尖锐角

例子:BlackBerry真正的后台运行程序,Task里面看不到的哦_黑莓手机guid-程序员宅基地

文章浏览阅读5k次。说明:1.BlackBerry_App_Descriptor.xml设置程序为Auto-run on startup,Do not display the application icon on the BlackBerry home screen2.手机开机后自动运行 BackgroundApplication3.主程序BackgroundApplication的main中,执行BackgroundThread.waitForSingleton().start();启动后台线程4.BackgroundTh_黑莓手机guid

oracle中查找执行效率低下的SQL_oracle 怎么抓取执行慢的sql-程序员宅基地

文章浏览阅读9.9k次。oracle中查找执行效率低下的SQLkt431128 发布于 9个月前,共有 0 条评论v$sqltext:存储的是完整的SQL,SQL被分割v$sqlarea:存储的SQL 和一些相关的信息,比如累计的执行次数,逻辑读,物理读等统计信息(统计)v$sql:内存共享SQL区域中已经解析的SQL语句。(即时) select opname, ta_oracle 怎么抓取执行慢的sql

linux下iso8859乱码,在Linux上转换UTF-8和ISO-8859之间的文件-程序员宅基地

文章浏览阅读3k次。每当我遇到Unicode时,都没有用.我在Linux上,我从Windows获得这些文件:$file *file1: UTF-8 Unicode textfile2: ISO-8859 textfile3: ISO-8859 text在我发现文件有不同的编码之前,没有任何工作.我希望让我的生活变得轻松,并将它们全部放在相同的格式中:iconv -f UTF-8 -t ISO-8859 file1 &..._iso-8859 text

如何确定当前项目是采用 Vite 还是 Vue CLI 项目

检查项目根目录下是否有一个名为或的文件。这是 Vite 项目的配置文件。在文件中,查看和部分是否包含vite和(对于 Vue 3)或(对于 Vue 2)。

如何在Linux服务器上安装Stable Diffusion WebUI

如何在Linux服务器上安装Stable Diffusion WebUI

推荐文章

热门文章

相关标签