帝 国cms模板教程之栏目自定义字段调用教程及代码_3.doc
文本预览下载声明
帝国cms模板教程之栏目自定义字段调用教程及代码
首先说一下,我这里用的到带模板的栏目导航标签(showclasstemp),用其它标签需要修改其它函数,但我相信万变不离其中,原理都是一样的,为了让大家学会这个东东,我就从简单的开始说起
一、首先点模板管理,找到左边从最下面往上数第三个,其中有一个标签管理,点击后在右边找到showclasstemp这个标签,点击修改后可以看到该标签所使用的函数名称(sys_ShowClassByTemp),我们需要修改的就是这个函数
二、我在我自己做的站中增加了两个自定义字段(pic,entitle),一个是栏目前面显示的小图标,一个是英文名
三、打开e/class/t_functions.php 这个文件,帽似帝国的函数处理都 在这个文件中进行
四、现在仔细看看第一步中找到的那个函数名,记下来,在t_functions.php这个文件中找到他,7.0测试版大概是在1574行,6.6的大概在1889行,在这个函数中找到下面的代码:
$sql=$empire-query(select classid,classname,islast,sonclass,tbname,intro,classimg from {$dbtbpre}enewsclass where bclassid=$classid and showclass=0 order by myorder,classid.$limit);
替换成以下代码:
$sql=$empire-query(SELECT C.classid,C.classname,C.islast,C.islast,C.tbname,C.intro,C.classid,C.classimg,C.infos,D.classid,D.pic,D.entitle FROM {$dbtbpre}enewsclass C LEFT JOIN {$dbtbpre}enewsclassadd D ON C.classid=D.classid where C.bclassid=$classid and C.showclass=0 order by myorder,C.classid
.$limit);
这里说下这是什么意思,高手请飘过,呵呵
帝国的这个栏目字段跟自定义栏目字段不在同一个表中,所以他原来的单一查询就查不到自定字段的值,这里我们只需要把这个查询改成复合查询,把自定义字段的表带进来一起查询就可以了
呵呵
刚才的查询我们己经可以把数据查到了,现在需要做的就是替换到模板里面去就OOK 了,继续!
五、找到以下代码,把我们添加的字段变量加进去
//替换变量
$bclassname=$class_r[$classid][classname];
$br[classid]=$classid;
$bclassurl=sys_ReturnBqClassname($br,9);
$listtemp=str_replace([!--bclassname--],$bclassname,$listtemp);
$listtemp=str_replace([!--bclassurl--],$bclassurl,$listtemp);
$listtemp=str_replace([!--bclassid--],$classid,$listtemp);
修改为:
//替换变量
$bclassname=$class_r[$classid][classname];
$br[classid]=$classid;
$bclassurl=sys_ReturnBqClassname($br,9);
$listtemp=str_replace([!--pic--],$pic,$listtemp);
$listtemp=str_replace([!--entitle--],$entitle,$listtemp);
$listtemp=str_replace([!--bclassname--],$bclassname,$listtemp);
$listtemp=str_replace([!--bclassurl--],$bclassurl,$listtemp);
$listtemp=str_replace([!--bclassid--],$classid,$listtemp);
六,最后一步:
把变量替换到模板中,找到以下代码:
//栏目名称
$listtemp=str_replace([!--classname--],$r[classname],$listtemp);
//栏目id
$listtemp=str_replace([!--classid--],$r[c
显示全部