您现在的位置是: 主页 > 个人博客日记 > 程序人生 > 程序人生

dedeCMS调用顶级二级栏目及下三级栏目方法

2019-06-29 15:57 【程序人生】 人已围观

简介: ①:通过dede调用二级栏目大家都会调用,但要调用三级栏目,就有点麻烦了,如下样式的三级栏目dede如何调用呢?如下: ----------------------------------------A级主栏目 +顶级栏目 +二级栏目...

  ①:通过dede调用二级栏目大家都会调用,但要调用三级栏目,就有点麻烦了,如下样式的三级栏目dede如何调用呢?如下:

  ----------------------------------------A级主栏目

  +顶级栏目

  +二级栏目

  +三级栏目(A)

  +三级栏目(B)

  +三级栏目(C)

  +二级栏目

  +三级栏目(D)

  +三级栏目(E)

  +三级栏目(F)

  ----------------------------------------B级主栏目

  +顶级栏目

  +二级栏目(G)

  +二级栏目(H)

  +二级栏目(I)

  {dede:channelartlist typeid=6 row=4} (注:这是顶级栏目id)

  {dede:field name='typename'/} (注:这是二级栏目名称)

  {dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}

  [field:typename/]

  (注:这是三级栏目的静态路径和栏目名称)

  {/dede:sql}

  {/dede:channelartlist}

  因为[field:typedir /]在数据库存储的路径包括{cmspath}这个字符串,所以我们必须处理一下,就用到织梦(dedecms)自带的cn_substr这个系统函数,这里简要说一下这个函数的参数,@me是当前字段值,也就是取出的[field:typedir /]这个值,200和9表示从第9个字符位置( (不包括这个字符))开始截取200个字符。

  {dede:channelartlist typeid='1'}

  {dede:field name='typename'/}

  {dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,10'}

  [field:typename/]

  {/dede:sql}

  {/dede:channelartlist}

  {dede:channelartlist typeid='1'}

  {dede:field name='typename'/}

  {dede:sql sql='Select * from dede_arctype where reid=~id~'}

  [field:typename/]

  {/dede:sql}

  {/dede:channelartlist}

  主栏目调用

  {dede:channelartlist typeid=top row=''}

  {dede:field name='typename'/}

  {dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}

  [field:array runphp='yes']@me = (!empty(@me['reid']) ? "" : "

  {@me['typename']}

  "); [/field:array]

  {/dede:sql}

  {/dede:channelartlist}

  在列表页和内容页调用顶级栏目名称方法

  {dede:field.typeid runphp='yes' function="GetTopid(@me)"}

  $dsql = new DedeSql(false);

  $a="SELECT typename FROM dede_arctype where id=@me";

  $arcRow = $dsql->GetOne($a);

  @me=$arcRow[typename];{/dede:field.typeid}

  根据下级栏目获得顶级栏目名称的SQL语句

  {dede:field.typeid runphp='yes'}$ID = @me; $sql = "SELECT * FROM `dede_arctype` WHERE id=$ID";$query = mysql_query($sql);$row=mysql_fetch_array($query); $relID = "$row[reid]"; if($relID == 0) {@me = $row[typename];}else{$sql = "SELECT `typename` FROM `dede_arctype` WHERE id=$relID";$query = mysql_query($sql);$row=mysql_fetch_array($query); @me = $row[typename];}{/dede:field.typeid}

  怎么在首页调用dede子栏目

  {dede:channel type='son' typeid='栏目ID'}

  [field:typename/]

  {/dede:channel}

孟文鹏博客版权所有丨如未注明 , 均为原创丨 转载请注明dedeCMS调用顶级二级栏目及下三级栏目方法

很赞哦! ( )

随机图文

文章评论

    总共有: 条评论 来说两句吧...

    用户名:

    联系方式:

猜你喜欢

站点信息

  • 建站时间 :2019-6-18
  • 共有会员 : 2名
  • 共有文章 :3138篇
  • 今日更新 :11篇
  • 百度收录
  • 文章阅读 :433603人次
  • 公众号 :扫描二维码,关注我们