Need help in creating dynamic menu
我正在使用 PHP 开发一个网站,这是我第一次尝试动态菜单。
我正在做的是为页面创建了一个表格。
表结构如下:
1 2 3
| ____________________________________________________________________________
|page_id|title|url|content|menu_title|show_on_navuigation|is_sub|parent_page|
|_______|_____|___|_______|__________|___________________|______|___________| |
这里的is_sub表示是否是某个主菜单的下拉菜单。 parent_page 是子菜单的主菜单。
现在,我想要的是,像
我创建了 2 个父页面:
About Us 和 Test
和 2 个子菜单:Test aboutus 和 testsub,
Test aboutus 是 About Us 的 sub,testsub 是 test.
查询和循环实际上应该如何,以便菜单完美呈现。
提前致谢。
这是我的菜单结构:
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 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
| <ul >
<li class='has-sub'><span >About Us </span >
<ul >
<li >
<span >Corporate Profile </span >
</li >
<li class='last'><span >Vision & Mission </span >
</li >
</ul >
</li >
<li class='has-sub'><span >Business Services </span >
<ul >
<li >
<span >Recruitment </span >
</li >
<li >
<span >Training </span >
</li >
<li >
<span >Executive Search </span >
</li >
<li >
<span >Payroll </span >
</li >
<li class='last'><span >Background Verification </span >
</li >
</ul >
</li >
<li class='has-sub'><span >Employers </span >
<ul >
<li >
<span >Enquiry </span >
</li >
<li >
<span >Job Description </span >
</li >
<li >
<span >Employer Contract </span >
</li >
<li class='last'><span >Feedback </span >
</li >
</ul >
</li >
<li class='has-sub'><span >Job Seeker </span >
<ul >
<li >
<span >Apply For Job /Register </span >
</li >
<li >
<span >Career Tips </span >
</li >
<li >
<span >Interview Questions </span >
</li >
<li >
<span >Interview Process </span >
</li >
<li class='last'><span >Corporate Dress </span >
</li >
</ul >
</li >
<li class='has-sub'><span >Franchise </span >
<ul >
<li class='last'><span >Franchise Enquiry Form </span >
</li >
</ul >
</li >
<li class='last'><span >Contact us </span >
</li >
</ul >
<?php
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `pages` WHERE `parent_page` = '$parent_page_id'"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
echo '
<li>
' . $result['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
$get_base_menu = mysql_query("SELECT * FROM pages WHERE parent_page = 0");
while($fetch_base_menu = mysql_fetch_array($get_base_menu))
{
$parent_page_id = $fetch_base_menu['page_id'];
displayMenu ($parent_page_id);
} |
?>
- 你真的想用 mysql 为菜单做所有这些工作吗?整个站点的菜单通常相同,很少更改。因此,我认为,将其硬编码为 HTML 是有道理的。我认为,如果您要经常更改它,并且如果您正在创建某种"后端"来为您的最终用户提供一种编辑菜单结构的方法,那么将其放入数据库中才有意义。否则,为什么要为此使用数据库?
-
是的,巴特尔。客户希望将来可以添加更多页面。所以我不得不为页面和菜单创建一个表格
-
@ButtleButkus 这就是我的想法。通常菜单项通常是相同的,除了可能会更改登录/注销和注册/登录的内容。
-
Vishal,因此您的客户可能希望在菜单中创建任意数量的级别,以访问不同的页面。但是他们将如何创建页面?我假设如果他们要处理新页面的编码,他们可以处理向菜单"小部件"添加一些 HTML。
-
Buttle,我在后端创建了一个表单,以便能够创建页面。
-
我会在一分钟内给你一些答案。
-
好的,巴特尔。热切地等待答案
-
实际上,您可以发布您希望 HTML 的样子吗?例如。是使用 ul 的下拉菜单吗?
-
这是静态结构:
-
<ul>
\\t<li class='has-sub'><span>关于我们</span>
<ul>
<li>
<span>公司简介</span>
</li>
<li class='last'><span>愿景
-
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)
使用参数 "0" 调用函数应该会给你完整的菜单树。
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
| $trace = array();
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
$trace[] ="Page_id $parent_page_id has no children";
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
$trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
echo '
<li>
' . $row['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
displayMenu (0); // call function for base level
var_dump($trace); |
更多信息:
我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!
但是,我想我是在另一个网站上找到的,这里:
http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/
434511
我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。
我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。
-
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)
使用参数 "0" 调用函数应该会给你完整的菜单树。
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
| $trace = array();
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
$trace[] ="Page_id $parent_page_id has no children";
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
$trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
echo '
<li>
' . $row['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
displayMenu (0); // call function for base level
var_dump($trace); |
更多信息:
我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!
但是,我想我是在另一个网站上找到的,这里:
http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/
434511
我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。
我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。
-
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)
使用参数 "0" 调用函数应该会给你完整的菜单树。
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
| $trace = array();
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
$trace[] ="Page_id $parent_page_id has no children";
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
$trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
echo '
<li>
' . $row['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
displayMenu (0); // call function for base level
var_dump($trace); |
更多信息:
我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!
但是,我想我是在另一个网站上找到的,这里:
http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/
434511
我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。
我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。
-
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)
使用参数 "0" 调用函数应该会给你完整的菜单树。
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
| $trace = array();
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
$trace[] ="Page_id $parent_page_id has no children";
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
$trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
echo '
<li>
' . $row['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
displayMenu (0); // call function for base level
var_dump($trace); |
更多信息:
我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!
但是,我想我是在另一个网站上找到的,这里:
http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/
434511
我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。
我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。
-
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)
使用参数 "0" 调用函数应该会给你完整的菜单树。
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
| $trace = array();
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
$trace[] ="Page_id $parent_page_id has no children";
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
$trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
echo '
<li>
' . $row['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
displayMenu (0); // call function for base level
var_dump($trace); |
更多信息:
我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!
但是,我想我是在另一个网站上找到的,这里:
http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/
434511
我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。
我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。
我强烈建议尝试摆脱使用邻接列表模型并转向更易于管理的解决方案,例如嵌套集。使用 MPTT 类型的解决方案可以帮助您更轻松地管理分层数据。使用邻接列表模型时,您会受到一定程度的限制。
我建议考虑使用 Zebra_MPTT 或其他形式的 MPTT 库。请查看这篇关于在 MySQL 中管理分层数据的文章。
-
看起来我们对 Hillyer 链接达成了共识。
-
确实 :) 不久前我读过另一篇文章,但我现在很难找到它。
-
我的书签中有上面的一个,但出于某种原因,他们从 mysql.com 中删除了它。幸运的是,我可以通过谷歌搜索保存在我的谷歌书签中的标题找到它。
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有 parent_page_id = 0 用于基本级别的菜单项。 (我使用 parent_page_id 而不是 parent_page 因为我认为这就是您的意思,而且答案更清楚。)
使用参数 "0" 调用函数应该会给你完整的菜单树。
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
| $trace = array();
function displayMenu ($parent_page_id) {
$sql ="SELECT * FROM `tbl_menu` WHERE `parent_page_id` = $parent_page_id"; // sql
$result = mysql_query($sql);
if( mysql_num_rows($result) === 0 ) { // mysql_num_rows() is deprecated, but you are using mysql extension so that's why I show it here
$trace[] ="Page_id $parent_page_id has no children";
return true; // exit function
} // else, continue to rest of function
echo '
<ul>
';
while($row = mysql_fetch_assoc($result)) { // deprecated mysql php function here for simplicity
$trace[] ="Entered while loop for page_id = $parent_page_id"; // not an error, just tracking
echo '
<li>
' . $row['menu_title'] . ''; // no closing
</li >
yet
displayMenu ($row['page_id']); // this is the recursive part
echo '
</li>
'; // close the
<li >
from before the recursion
}
echo '
</ul>
';
}
displayMenu (0); // call function for base level
var_dump($trace); |
更多信息:
我之前研究过这个主题,并且有一个很好的链接到 mysql.com 上的一个页面,其中深入探索了分层关系数据库结构。但是当我检查时,链接已损坏!
但是,我想我是在另一个网站上找到的,这里:
http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/
- 巴特尔我正在使用 mysql_query
-
巴特尔,如果我有任何疑问,我会尽力回复您。谢谢
-
行。我更改了代码以使用 mysql 函数并输入了实际的 mysql 查询,除了我使用 parent_page_id 而不是 parent_page 因为这对其他人来说更清楚。
-
是的,好的,巴特尔。试试看
-
嗨 Buttle,我已经发布了我在问题中写的查询。它没有显示任何输出。我只能在查看源代码中看到 html 标签,但在标签内看不到文本。我写的是否正确。如果有更改,请告诉我
-
啊,Vishal,你应该发现我的错误。我有 $result['url'] 和 $result['menu_tile']。现在修好了。 $row 是变量,而不是 $result。在我意识到错误是什么之前,我还添加了 $trace 变量来检查事情。
-
很高兴它奏效了。嘿,谢谢你的复选标记!如果你不介意也给我一个赞成票,我也不介意!
-
我试过巴特尔。但这不会允许我,因为我没有足够的声誉。对不起
-
你是个天才。我想知道我成为这样的编码员需要多长时间 :)
-
哈哈谢谢夸奖。我想如果你每天花几个小时,那么你可能也需要 1-2 年才能成为天才。