帝国CMS替换当前位置导航[!---newsnav--]标签,实现样式自定义!

帝国CMS替换当前位置导航[!---newsnav--]标签,实现样式自定义!

浏览次数:
作者: 墨鱼
信息来源: 本站原创
更新日期: 2015-10-30 00:45:38
文章简介

帝国CMS教程:替换当前位置导航[!---newsnav--]标签,轻松实现样式自定义。通过简单步骤,您可以对导航条进行个性化设计,满足网站风格需求。本教程专注于指导您如何仅输出一条自定义样式的导航,让网站导航更加美观且符合用户体验。无需复杂代码,快速上手,提升网站专业度。

  • 正文开始
  • 相关阅读
  • 推荐作品

 官方的[!--newsnav--]有什么不足?

 

1、样式死板 输出的样式写死在程序里 要修改只能改官方源码 升级时会痛苦不堪
2、有的栏目用的二级域名,比如资讯页面,我想[!--newsnav--]显示的是 资讯首页>xxx>xxx 而不是 首页>资讯>xxx>xxx,用[!--newsnav--]就实现不了

 

所以要改进,如何改进?

 

第一步:在e/class/userfun.php中加入下面的函数
//当前位置导航
function user_linknav($classid){
        global $empire,$dbtbpre,$navclassid,$class_r,$public_r;
        //当前栏目
        if($classid=="selfinfo"){
                if(empty($navclassid)){
                        $classid=0;
                }else{
                        $classid=$navclassid;
                        //终极类别则显示同级类别
                        if($class_r[$classid][islast]&&$class_r[$classid][bclassid]){
                                $classid=$class_r[$classid][bclassid];
                        }
                        if($class_r[$classid][islast]&&empty($class_r[$classid][bclassid])){
                                $classid=0;
                        }
                }
        }
        $query="select classname,bclassid,classpath from {$dbtbpre}enewsclass  where classid=".$classid;
 
        $sql=$empire->query($query);
        echo '<a href = "/">首页</a>';
        while($r=$empire->fetch($sql)){
                findparent($r[bclassid]);
                echo ' > <a href ="/'.$r[classpath].'">'.$r[classname].'</a>';
        }
}
//当前位置导航,递归查询父栏目
function findparent($classid){
        global $empire,$dbtbpre;
        $query="select classname,bclassid,classpath from {$dbtbpre}enewsclass  where classid=".$classid;
        $sql=$empire->query($query);
        while($r=$empire->fetch($sql)){
                findparent($r[bclassid]);
                $prefix="";
                if($r[bclassid]){$prefix = ' > ';}
                echo $prefix.'<a href ="/'.$r[classpath].'">'.$r[classname].'</a>';
        }
}
第二步:在模板里,以前写[!--newsnav--]的地方,直接替换成

  

<?user_linknav($GLOBALS[navclassid]);?>

这里代码直接照搬了前辈的代码,只是有些小改动,较之于前辈的贴子,这篇里的代码改动了
1、findparent函数里加了一行判断,如果是顶级栏目了,则前面不加“ > ”,否则再加
2、调用该功能时,不使用标签,直接写php代码,省去一步麻烦
帝国CMS如何在"JS调用登陆模板"中调用当前登陆用户的头像?
« 上一篇 2015年10月25日
帝国CMS内容页调用会员组ID 支持静态页生成
下一篇 » 2015年11月06日
  • 微软bing IndexNow的推送和管理-帝国CMS插件
    23阅读0条评论0个赞
    微软Bing IndexNow推送管理插件,专为帝国CMS打造。本教程指导您如何高效利用该插件,实现网站内容快速被Bing搜索引擎收录。通过简单配置,即可自动化推送新发布或更新的页面至Bing,加速索引过程,提升网站SEO效果。轻松管理推送历史,监控索引状态,确保网站内容及时展现给目标用户。优化网站可见性,从掌握Bing IndexNow推送管理开始。
  • 帝国CMS8.0测试版搜索结果页只显示第1页的解决方法
    50阅读0条评论0个赞
    对于刚安装帝国CMS8.0测试版尝鲜的小伙伴们可能发现,使用高级搜索的时候结果页只显示第1页,虽然帝国CMS开发者说正式版会解决此问题,但是临时使用还是要先解决这个问题的。所以今天墨鱼就说下临时的解决方法。
  • 【优化分享】帝国CMS大数据量筛选性能瓶颈突破实践
    243阅读0条评论5个赞
    突破帝国CMS大数据筛选性能瓶颈实战教程:掌握高效技巧,轻松应对海量数据处理挑战。本教程详解性能优化策略,助力快速筛选,提升系统响应速度。无论你是开发者还是管理员,都能从中获益,实现数据筛选效率飞跃,让帝国CMS在大数据环境下依然流畅运行。立即学习,解锁大数据处理新技能!
  • 帝国CMS统计多个数据表今日更新总数代码
    166阅读0条评论4个赞
    帝国CMS统计多表今日更新总数代码教程:通过SQL查询结合帝国CMS函数,汇总多个数据表中今日更新的记录总数。步骤包括编写SQL联合查询语句,利用`DATE()`函数筛选今日数据,结合帝国CMS的数据库操作函数执行查询,并输出结果。此教程教你高效获取多表今日更新概况,优化管理效率。
  • 帝国cms7.5无刷新 Ajax 点击加载更多列表信息源代码
    825阅读2条评论13个赞
    帝国CMS 7.5 Ajax无刷新加载,高效实现点击加载更多列表信息,精简源码仅展示核心功能,优化用户体验,提升网页加载效率。

如本文对您有帮助,就请墨鱼抽根烟吧!