在帝国cms中调用全站导航主要通过标签和自定义函数实现。1. 使用[e:loop]结合showclasstemp标签查询数据库中的顶级栏目(bclassid=0)并输出一级栏目列表,若需展示二级栏目则嵌套php子查询;2. 自定义函数方式更灵活,可在userfun.php中添加如get_all_nav函数封装导航逻辑,便于复用与维护;3. 注意事项包括:多级菜单需手动添加子查询、修改后需更新栏目缓存、高亮当前栏目需比对classid、路径问题需根据需求处理相对或完整url。掌握sql查询与循环结构是成功调用导航的关键。
调用全站导航在帝国cms中其实是一个比较常见的需求,尤其是在做网站头部或底部全局导航菜单时。要实现这个功能,主要就是通过系统自带的标签和自定义函数来完成。
1. 使用[showclasstemp]标签调用栏目导航
这是最基础也是最常用的方式之一,适合用于展示一级栏目或者带子栏目的结构。
写法示例:
<ul> [e:loop={"select classid,classname from {$dbtbpre}enewsclass where bclassid=0 order by myorder,classid",0,24,0}] <?php $classurl=sys_ReturnBqClassname($bqr,9); // 获取栏目链接 ?> <li><a href="<?=$classurl?>"><?=$bqr[classname]?></a></li> [/e:loop] </ul>
这段代码会从数据库中读取顶级栏目(bclassid=0),然后循环输出成一个无序列表。你可以把它放在模板中的任意位置,比如header或footer里。
如果你还想显示二级栏目,可以在每个一级栏目下再嵌套一个查询:
<?php $sub_sql = "select classid,classname from {$dbtbpre}enewsclass where bclassid='$bqr[classid]' order by myorder,classid"; $sub_result = $empire->query($sub_sql); while($sub_r = $empire->fetch($sub_result)) { $sub_url = sys_ReturnBqClassname($sub_r,9); echo "<li><a href='{$sub_url}'>{$sub_r[classname]}</a></li>"; } ?>
注意:这种方式需要你把[e:loop]换成纯PHP方式调用,否则不能嵌套使用。
2. 自定义导航函数更灵活
如果默认方式不够灵活,比如你想按特定顺序展示栏目、排除某些栏目,或者添加图标、高亮当前栏目等效果,可以考虑写一个自定义函数。
步骤如下:
- 打开 e/class/userfun.php
- 添加一个函数,比如:
function get_all_nav() { global $empire,$dbtbpre; $nav = ''; $sql = "select classid,classname from {$dbtbpre}enewsclass where bclassid=0 order by myorder,classid"; $result = $empire->query($sql); while($r = $empire->fetch($result)) { $classurl = sys_ReturnBqClassname($r,9); $nav .= "<li><a href='{$classurl}'>{$r[classname]}</a></li>"; } return $nav; }
- 在模板中使用 [!–get_all_nav–] 调用即可。
这种方式的好处是便于维护,也方便你在多个模板中复用。
3. 注意事项与常见问题
- 栏目层级限制:默认情况下,只展示一级栏目,如需多级导航需要手动加子查询。
- 栏目缓存影响:有时候修改了栏目排序或名称后前台没变化,可能是缓存导致,记得更新栏目缓存。
- 高亮当前栏目:可以通过判断当前页面的classid是否等于循环中的classid来加active样式。
- URL路径问题:sys_ReturnBqClassname函数生成的是完整路径,但有些主题可能希望用相对路径,这时候需要手动处理。
基本上就这些方法了。虽然不复杂,但要注意细节,尤其是涉及多级菜单的时候,逻辑容易出错。只要理清楚SQL查询和循环结构,调用全站导航就没太大问题。