首先说一下,我这里用的到带模板的栏目导航标签(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[classid],$listtemp);
//栏目图片
if(empty($r[classimg]))
{
$r[classimg]=$public_r[newsurl].e/data/images/notimg.gif;
}
$listtemp=str_replace([!--classimg--],$r[classimg],$listtemp);
//栏目简介
$listtemp=str_replace([!--intro--],nl2br($r[intro]),$listtemp);
//记录数
$listtemp=str_replace([!--num--],$num,$listtemp);
//序号
$listtemp=str_replace([!--no--],$no,$listtemp);
return $listtemp;
在这上面增加几行,修改后的代码如下:
//栏目小图标
$listtemp=str_replace([!--pic--],$r[pic],$listtemp);
//栏目英文名
$listtemp=str_replace([!--entitle--],$r[entitle],$listtemp);
//栏目名称
$listtemp=str_replace([!--classname--],$r[classname],$listtemp);
//栏目id
$listtemp=str_replace([!--classid--],$r[classid],$listtemp);
//栏目图片
if(empty($r[classimg]))
{
$r[classimg]=$public_r[newsurl].e/data/images/notimg.gif;
}
$listtemp=str_replace([!--classimg--],$r[classimg],$listtemp);
//栏目简介
$listtemp=str_replace([!--intro--],nl2br($r[intro]),$listtemp);
//记录数
$listtemp=str_replace([!--num--],$num,$listtemp);
//序号
$listtemp=str_replace([!--no--],$no,$listtemp);
return $listtemp;
七、还有最后一步,最要紧,至关重要的,绝对不能丢掉的,千万要注意的就是
呵呵,在showclasstemp调用的标签模板中记得加上调用代码,怎么调用呢,就特别特别特别特别滴轻松了,看看我是怎么调用的,
1
<li><span><img src=[!--pic--] width=19 height=21 /></span><a href=[!--classurl--]>[!--classname--]</a><b>[!--entitle--]</b></li>
更多信息请查看IT技术专栏