帝国和织梦的栏目都是无限级分类,也正因为这个无限级分类,带来了很多的问题,去年我做了一个获取当前栏目的最顶级栏目的功能,这个其实比较简单,我们只需要写一个无限循环查询,查当前栏目的上级栏目,一直查到他的父栏目再没有父栏目即可,返回这个栏目的信息就可以了。而今天说的这个就相对麻烦了,因为一个栏目有多个子栏目,子栏目又可能有多个子栏目,我们并不是仅仅读出来他的下级而已,而是读出来所有的子栏目。这里以帝国和织梦为例来说一下(个人比较推崇帝国cms,其标签和php混编非常的好用,甚至可以在模板中定义php函数来使用),先看效果。
这个效果图是以帝国为例的,可以看到我是将当前栏目的所有子栏目中是最终级栏目的id读了出来,我们可以根据自己的需要改动一下这个函数即可。
实现方法,我们可以看一下帝国的数据库,其栏目表是:phome_enewsclass,其实所有的无限级分类,肯定都是每个记录有存储他的父类的字段。我们就通过这个来获取所有他的子栏目。代码:
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 |
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; } |
将上面这个代码加到帝国的函数库文件:e/class/functions.php里面
我们看这个代码的意思,就是调用sonclass1,给他两个参数,第一个是当前栏目的id,第二个是数据表的前缀,这些参数都可以直接在前台模板获得到,
然后我们看看前台模板的写法,
我们一般是在列表页用到,就拿列表模板举例,帝国的封面模板是不能发文章的,但是他依然可以是用列表页模板而非封面模板,并且模板中可以直接写php代码即可,
我是这样写的:
1 2 3 |
<?php echo sonclass1($GLOBALS[navclassid],$dbtbpre); ?> |
模板中已经加载了函数库文件,所以可以直接使用这个函数。$GLOBALS[navclassid],$dbtbpre这两个参数就是一个获取当前的栏目id,一个是获取数据表的前缀。这样就实现了读出所有子栏目中为最终极栏目的id,当然我们就可以根据我们的需要进行修改即可。而有的人会觉得既然可以直接写php代码,那这个函数为什么不直接定义在这个模板中,原因是,这个模板会被多次调用,因为有多个栏目用了这个模板,所以里面的这个函数就会被定义多次,而我们知道,一个同名函数是不能被多次定义的,所以除非这个模板仅使用一次,那我们就可以直接在模板中定义, 不是,就需要在函数库中定义了。
而织梦同样功能的实现也是一样的,我们也是找到他的函数库文件,改一下这个函数里面的字段即可!
本文链接:http://www.521php.com/archives/1109/
程序本天成,妙手偶得之!我们只是代码的搬运工!
转载请注明:http://www.521php.com/archives/1109/