在织梦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);