评论

收藏

[帝国CMS] 帝国CMS调用自定义列表名称的方法(简单二次开发实现)

建站程序 建站程序 发布于:2021-07-19 15:12 | 阅读数:711 | 评论:0

本文讲述了帝国CMS调用自定义列表名称的方法,脚本之家在这里提供了2种实现方法,涉及针对帝国CMS底层代码的修改。具体如下:
一、问题描述:
需要调出自定义列表名称,如下图所示:
DSC0000.jpg

而使用帝国CMS原有的标签只能调用网页标题,而无法调出列表名称
二、解决方法:
方法一:
首先需要实现自定义列表可调出当前栏目ID,具体方法可参考脚本之家前面的教程《帝国CMS在自定义列表中获取当前列表ID的方法》。
能够在自定义列表通过$navclassid获取当前栏目ID的话,问题就变得非常简单了,使用灵动标签的SQL调用如下:

代码如下:
[e:loop={"select * from [!db.pre!]enewsuserlist where listid=$navclassid",1,24,0}]
<?=$bqr['listname']?>
[/e:loop]
这样就可以调出列表名了!
方法二:
修改帝国CMS源码,添加调用字段实现直接调用该名称。
具体操作如下:
步骤1:
打开e\admin\other\ListUserlist.php文件,在大约147行找到刷新自定义列表函数function DoReUserlist($add,$userid,$username){
在该函数的查找调用数据库字段部分找到这段代码:

代码如下:
$ur=$empire->fetch1("select listid,pagetitle,filepath,filetype,totalsql,listsql,maxnum,lencord,listtempid,pagekeywords,pagedescription from {$dbtbpre}enewsuserlist where listid='".$listid[$i]."'");
添加listname字段,改成如下形式:

代码如下:
$ur=$empire->fetch1("select listid,listname,pagetitle,filepath,filetype,totalsql,listsql,maxnum,lencord,listtempid,pagekeywords,pagedescription from {$dbtbpre}enewsuserlist where listid='".$listid[$i]."'");
如下图所示:
DSC0001.jpg

步骤2:
打开e\class\functions.php,在大约2467行找到生成信息列表函数function ListHtml($classid,$fields,$enews=0,$userlistr=

){
添加自定义字段

代码如下:
$GLOBALS['navclasslistname']=$enews==4?$userlistr['listname']:"";
如下图所示:
DSC0002.jpg

至此,就可以在列表模板使用$GLOBALS['navclasslistname']调用自定义列表名称
希望本文所述对大家基于帝国CMS的网站程序设计有所帮助。

关注下面的标签,发现更多相似文章