帝国和织梦的栏目都是无限级分类,也正因为这个无限级分类,带来了很多的问题,去年我做了一个获取当前栏目的最顶级栏目的功能,这个其实比较简单,我们只需要写一个无限循环查询,查当前栏目的上级栏目,一直查到他的父栏目再没有父栏目即可,返回这个栏目的信息就可以了。而今天说的这个就相对麻烦了,因为一个栏目有多个子栏目,子栏目又可能有多个子栏目,我们并不是仅仅读出来他的下级而已,而是读出来所有的子栏目。这里以帝国和织梦为例来说一下(个人比较推崇帝国cms,其标签和php混编非常的好用,甚至可以在模板中定义php函数来使用),先看效果。
这个效果图是以帝国为例的,可以看到我是将当前栏目的所有子栏目中是最终级栏目的id读了出来,我们可以根据自己的需要改动一下这个函数即可。
实现方法,我们可以看一下帝国的数据库,其栏目表是:phome_enewsclass,其实所有的无限级分类,肯定都是每个记录有存储他的父类的字段。我们就通过这个来获取所有他的子栏目。代码:
帝国cms获取当前栏目下所有需要的子栏目信息(包括子栏目的子栏目等)
PHP
function sonclass1($cid,$dbtbpre){
$sql="select classid,classname,islast from {$dbtbpre}enewsclass where bclassid = '$cid'";
$query=mysql_query($sql);
$id = '';
while($c = mysql_fetch_array($query)){
if('1'==$c['islast']){
$id .=$c['classid'].',';
}else{
$id .=sonclass2($c['classid'],$dbtbpre);
}
}
if($id){
return $id;
}else{
return false;
}
}
function sonclass2($cid,$dbtbpre){
$sql="select classid,classname,islast from {$dbtbpre}enewsclass where bclassid = '$cid'";
$query=mysql_query($sql);
$id = '';
while($c = mysql_fetch_array($query)){
if('1'==$c['islast']){
$id .=$c['classid'].',';
}else{
$id .=sonclass2($c['classid'],$dbtbpre);
}
}
return $id;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
functionsonclass1($cid,$dbtbpre){
$sql="select classid,classname,islast from {$dbtbpre}enewsclass where bclassid = '$cid'";
$query=mysql_query($sql);
$id='';
while($c=mysql_fetch_array($query)){
if('1'==$c['islast']){
$id.=$c['classid'].',';
}else{
$id.=sonclass2($c['classid'],$dbtbpre);
}
}
if($id){
return$id;
}else{
returnfalse;
}
}
functionsonclass2($cid,$dbtbpre){
$sql="select classid,classname,islast from {$dbtbpre}enewsclass where bclassid = '$cid'";
$query=mysql_query($sql);
$id='';
while($c=mysql_fetch_array($query)){
if('1'==$c['islast']){
$id.=$c['classid'].',';
}else{
$id.=sonclass2($c['classid'],$dbtbpre);
}
}
return$id;
}
将上面这个代码加到帝国的函数库文件:e/class/functions.php里面
我们看这个代码的意思,就是调用sonclass1,给他两个参数,第一个是当前栏目的id,第二个是数据表的前缀,这些参数都可以直接在前台模板获得到,
然后我们看看前台模板的写法,
我们一般是在列表页用到,就拿列表模板举例,帝国的封面模板是不能发文章的,但是他依然可以是用列表页模板而非封面模板,并且模板中可以直接写php代码即可,
我是这样写的:
PHP
echo sonclass1($GLOBALS[navclassid],$dbtbpre);
?>
1
2
3
echosonclass1($GLOBALS[navclassid],$dbtbpre);
?>
模板中已经加载了函数库文件,所以可以直接使用这个函数。$GLOBALS[navclassid],$dbtbpre这两个参数就是一个获取当前的栏目id,一个是获取数据表的前缀。这样就实现了读出所有子栏目中为最终极栏目的id,当然我们就可以根据我们的需要进行修改即可。而有的人会觉得既然可以直接写php代码,那这个函数为什么不直接定义在这个模板中,原因是,这个模板会被多次调用,因为有多个栏目用了这个模板,所以里面的这个函数就会被定义多次,而我们知道,一个同名函数是不能被多次定义的,所以除非这个模板仅使用一次,那我们就可以直接在模板中定义, 不是,就需要在函数库中定义了。
而织梦同样功能的实现也是一样的,我们也是找到他的函数库文件,改一下这个函数里面的字段即可!
程序本天成,妙手偶得之!我们只是代码的搬运工!
更多推荐
php获取当前栏目子栏目,帝国织梦cms获取当前栏目下所需的子栏目(包括子类的子类等)...
发布评论