php获取当前栏目子栏目,帝国织梦cms获取当前栏目下所需的子栏目(包括子类的子类等)...

帝国和织梦的栏目都是无限级分类,也正因为这个无限级分类,带来了很多的问题,去年我做了一个获取当前栏目的最顶级栏目的功能,这个其实比较简单,我们只需要写一个无限循环查询,查当前栏目的上级栏目,一直查到他的父栏目再没有父栏目即可,返回这个栏目的信息就可以了。而今天说的这个就相对麻烦了,因为一个栏目有多个子栏目,子栏目又可能有多个子栏目,我们并不是仅仅读出来他的下级而已,而是读出来所有的子栏目。这里以帝国和织梦为例来说一下(个人比较推崇帝国cms,其标签和php混编非常的好用,甚至可以在模板中定义php函数来使用),先看效果。

3ffc46c5556a2954e1d811c9f58455a1.png

20831271ef8d1e4ea918325939177c30.png

这个效果图是以帝国为例的,可以看到我是将当前栏目的所有子栏目中是最终级栏目的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代码即可,

我是这样写的:

3d6da4578272f22d2922873ed8e1d920.png

PHP

echo sonclass1($GLOBALS[navclassid],$dbtbpre);

?>

1

2

3

echosonclass1($GLOBALS[navclassid],$dbtbpre);

?>

模板中已经加载了函数库文件,所以可以直接使用这个函数。$GLOBALS[navclassid],$dbtbpre这两个参数就是一个获取当前的栏目id,一个是获取数据表的前缀。这样就实现了读出所有子栏目中为最终极栏目的id,当然我们就可以根据我们的需要进行修改即可。而有的人会觉得既然可以直接写php代码,那这个函数为什么不直接定义在这个模板中,原因是,这个模板会被多次调用,因为有多个栏目用了这个模板,所以里面的这个函数就会被定义多次,而我们知道,一个同名函数是不能被多次定义的,所以除非这个模板仅使用一次,那我们就可以直接在模板中定义, 不是,就需要在函数库中定义了。

而织梦同样功能的实现也是一样的,我们也是找到他的函数库文件,改一下这个函数里面的字段即可!

程序本天成,妙手偶得之!我们只是代码的搬运工!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值