我正在使用 PHP 开发一个网站,这是我第一次尝试动态菜单。
我正在做的是为页面创建了一个表格。
表结构如下:
2 3 | |page_id|title|url|content|menu_title|show_on_navuigation|is_sub|parent_page| |_______|_____|___|_______|__________|___________________|______|___________| |
这里的
现在,我想要的是,像
我创建了 2 个父页面:
和 2 个子菜单:Test aboutus 和 testsub,
Test aboutus 是 About Us 的 sub,testsub 是 test.
查询和循环实际上应该如何,以便菜单完美呈现。
提前致谢。
这是我的菜单结构:
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 | <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); } |
?>
<ul>
\\t<li class='has-sub'><span>关于我们</span>
<ul>
<li>
<span>公司简介</span>
</li>
<li class='last'><span>愿景
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有
使用参数 "0" 调用函数应该会给你完整的菜单树。
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 | 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 中管理分层数据的文章。
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有
使用参数 "0" 调用函数应该会给你完整的菜单树。
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 | 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 中管理分层数据的文章。
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有
使用参数 "0" 调用函数应该会给你完整的菜单树。
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 | 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 中管理分层数据的文章。
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有
使用参数 "0" 调用函数应该会给你完整的菜单树。
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 | 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 中管理分层数据的文章。
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有
使用参数 "0" 调用函数应该会给你完整的菜单树。
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 | 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 中管理分层数据的文章。
我认为对你来说最简单的代码就是这个递归函数。您所要做的就是将它放在您的页面上,并确保您有
使用参数 "0" 调用函数应该会给你完整的菜单树。
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 | 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/
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
如何使用RSpec::Core::RakeTask初始化RSpecRake任务?require'rspec/core/rake_task'RSpec::Core::RakeTask.newdo|t|#whatdoIputinhere?endInitialize函数记录在http://rubydoc.info/github/rspec/rspec-core/RSpec/Core/RakeTask#initialize-instance_method没有很好的记录;它只是说:-(RakeTask)initialize(*args,&task_block)AnewinstanceofRake
我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只
我实际上是在尝试使用RVM在我的OSX10.7.5上更新ruby,并在输入以下命令后:rvminstallruby我得到了以下回复:Searchingforbinaryrubies,thismighttakesometime.Checkingrequirementsforosx.Installingrequirementsforosx.Updatingsystem.......Errorrunning'requirements_osx_brew_update_systemruby-2.0.0-p247',pleaseread/Users/username/.rvm/log/138121
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我正在阅读SandiMetz的POODR,并且遇到了一个我不太了解的编码原则。这是代码:classBicycleattr_reader:size,:chain,:tire_sizedefinitialize(args={})@size=args[:size]||1@chain=args[:chain]||2@tire_size=args[:tire_size]||3post_initialize(args)endendclassMountainBike此代码将为其各自的属性输出1,2,3,4,5。我不明白的是查找方法。当一辆山地自行车被实例化时,因为它没有自己的initialize方法