dede获取任意栏目N级列表链接树形菜单

在织梦DEDECMS里获取顶级栏目很简单,一句 {dede:channel}{/dede:channel} 即可搞定。但有时我们需要在任意页面获取任意顶级栏目下的二级和san级栏目列表链接, {dede:channel} 就无能为力了。注意,我说的是在“任意”(首页、封面、列表、文章等)页面调用“任意”二或san级栏目列表。

  OK,一步步来,先第一个。(适用织梦dedecmsV4,V5.X未测试。)

  感谢双赢朋友帮忙测试。原来的函数在某些主机上进行生成html操作会提示 inc_channel_unit_functions.php 出错,现已改正。 

  一、在任意页面获取某顶级栏目下的二级栏目列表

  例如,我们要在首页或其他页面插入 产品展示 这个顶级栏目的下级栏目列表,

  1、在 /include/inc_functions.php 最后的 ?> 前加入以下代码:

  //在任意页面获取某顶级栏目下的二级栏目列表 用于channel标记 $typeid为顶级栏目ID

function getProductClass($typeid)

{

$linkList = "";

$dsql = new DedeSql(false);

$dsql->SetQuery("select typedir,typename from dede_arctype where reID = ‘$typeid’ order by sortrank");

$dsql->Execute();

while($row=$dsql->GetObject())

   $typelink = GetTypeUrl($row->ID,MfTypedir($row->typedir),$row->isdefault,$row->defaultname,$row->ispart,$row->namerule2);

   $linkList .= "<li>·<a href=http://www.dede58.com/"$typelink">".$row->typename."</a></li>n   ";

}

$dsql->Close();

return $linkList;

}

  2、在模板里用

  {dede:channel function=’getProductClass(2)’}{/dede:channel} 

  调用即可。这里getProductClass(2)中的 2 是产品展示的栏目ID。如果你的是其他的,请作相应修改。

    

  3、伪静态的话请用以下代码:

  //在任意页面获取某顶级栏目下的二级栏目列表 用于channel标记 $typeid为顶级栏目ID (用于伪静态)

function getProductClass($typeid)

{

$linkList = "";

$dsql = new DedeSql(false);

$dsql->SetQuery("select ID,typename from dede_arctype where reID = ‘$typeid’ order by sortrank");

$dsql->Execute();

while($row=$dsql->GetObject())

   $typelink = GetTypeUrl($row->ID,MfTypedir($row->typedir),$row->isdefault,$row->defaultname,$row->ispart,$row->namerule2);

   $linkList .= "<li>·<a href=http://www.dede58.com/"/list-".$row->ID.".html">".$row->typename."</a></li>n   ";

}

$dsql->Close();

return $linkList;

}

  (DEDECMS全站伪静态请看这里:DEDECMS全站(首页、列表、文章页)伪静态详细教程

  )

  二、在任意页面获取某顶级栏目下的二级栏目和san级栏目列表(树形菜单

  这里其实是取得一个树形菜单,共两级,如要多级的话,请自行参照修改。

  1、在 /include/inc_functions.php 最后的 ?> 前加入以下代码:

  //在任意页面获取某顶级栏目下的二级栏目和san级栏目列表 用于channel标记 $typeid为顶级栏目ID

function getProductTree($typeid)

{

$linkList = "";

$dsql = new DedeSql(false);

$dsql->SetQuery("select ID,typedir,typename from dede_arctype where reID = ‘$typeid’ order by sortrank");

$dsql->Execute();

while($row=$dsql->GetObject())

   $typelink = GetTypeUrl($row->ID,MfTypedir($row->typedir),$row->isdefault,$row->defaultname,$row->ispart,$row->namerule2);

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/bb175df59aa6ac0ff44a66fdf154d5c2.html