DEDECMS在任意页面获取任意栏目N级列表链接

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

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

感谢双赢朋友帮忙测试。原来的函数在某些主机上进行生成html操作会提示 inc_channel_unit_functions.php出错,现已改正。大家可放心使用。有问题请留言或点击QQ即时交流。

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

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

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

//在任意页面获取某顶级栏目下的二级栏目列表 用于channel标记 $typeid为顶级栏目ID
function getProductClass($typeid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("select typedir,typename from#@__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>·<ahref=\"$typelink\">".$row->typename."</a></li>\n 
  ";
}
$dsql->Close();
return $linkList;
}

2、在模板里用

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

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

3、效果如下:
DEDECMS在任意页面获取任意栏目N级列表链接_第1张图片

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

//在任意页面获取某顶级栏目下的二级栏目列表 用于channel标记 $typeid为顶级栏目ID (用于伪静态)
function getProductClass($typeid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("select ID,typename from #@__arctypewhere 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>·<ahref=\"/list-".$row->ID.".html\">".$row->typename."</a></li>\n    ";
}
$dsql->Close();
return $linkList;
}

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



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

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

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

//在任意页面获取某顶级栏目下的二级栏目和三级栏目列表 用于channel标记 $typeid为顶级栏目ID
function getProductTree($typeid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("select ID,typedir,typename from#@__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 .= "\n<li><ahref=\"$typelink\"><b>".$row->typename."</b></a></li>\n\n";
$linkList .= getSonClass($row->ID);
}
$dsql->Close();
return $linkList;
}
//获得小类栏目链接
function getSonClass($parentid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("Select ID,typedir,typename From#@__arctype where reID='$parentid' order by sortrank");
$dsql->Execute($parentid);
while($row=$dsql->GetObject($parentid))
{
$typelink =GetTypeUrl($row->ID,MfTypedir($row->typedir),$row->isdefault,$row->defaultname,$row->ispart,$row->namerule2);
$linkList .= "<liclass=\"smallclass\"><ahref=\"$typelink\">".$row->typename."</a></li>\n";
}
return $linkList;
}

2、在模板里用

{dede:channel function='getProductTree(2)'}{/dede:channel} 

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

3、效果如下:
DEDECMS在任意页面获取任意栏目N级列表链接_第2张图片

4、产生的代码如下:

<li><ahref="/product/ac-dc/"><b>AC/DC开关电源</b></a></li>

<liclass="smallclass"><ahref="/product/ac-dc/1-way/">一路输出10W-350W</a></li>
<liclass="smallclass"><ahref="/product/ac-dc/2-way/">二路输出15W-200W</a></li>
<liclass="smallclass"><ahref="/product/ac-dc/3-way/">三路输出15W-200W</a></li>
<liclass="smallclass"><ahref="/product/ac-dc/4-way/">四路输出30W-200W</a></li>

<li><ahref="/product/dc-dc/"><b>DC/DC开关电源</b></a></li>

<liclass="smallclass"><ahref="/product/dc-dc/1-way/">一路输出10W-200W</a></li>
<liclass="smallclass"><ahref="/product/dc-dc/2-way/">二路输出10W-150W</a></li>
<liclass="smallclass"><ahref="/product/dc-dc/3-way/">三路输出10W-150W</a></li>
<liclass="smallclass"><ahref="/product/dc-dc/4-way/">四路输出10W-150W</a></li>
。。。

在CSS里你就可以对 .smallclass 设置样式,如不同背景和缩进等。

更新:

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


//获得大类栏目链接
function getProductTree($typeid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("select ID,typename from #@__arctypewhere reID = '$typeid' order by sortrank");
$dsql->Execute();
while($row=$dsql->GetObject())
{
$linkList .= "\n<li><ahref=\"/list-".$row->ID.".html\"><b>".$row->typename."</b></a></li>\n\n";
$linkList .= getSonClass($row->ID);
}
$dsql->Close();
return $linkList;
}
//获得小类栏目链接
function getSonClass($parentid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("Select ID,typename From #@__arctypewhere reID='$parentid' order by sortrank");
$dsql->Execute($parentid);
while($row=$dsql->GetObject($parentid))
{
$linkList .= "<liclass=\"smallclass\"><ahref=\"/list-".$row->ID.".html\">".$row->typename."</a></li>\n";
}
return $linkList;
}

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



最诱人的更新:

三、在任意页面获取顶级栏目和二级栏目列表

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

加入第二点[二、在任意页面获取某顶级栏目下的二级栏目和三级栏目列表(树形菜单)]的两个函数,然后把第一个函数 functiongetProductTree($typeid) 里的:

select ID,typedir,typename from #@__arctype where reID = '$typeid'order by sortrank 改为:

select ID,typedir,typename from #@__arctype where reID = '0' orderby sortrank 就是把 $typeid 改为 0 。

2、在模板里用  {dede:channelfunction='getProductTree()'}{/dede:channel} 调用即可。效果如下图:


3、你可举一反三做成N级栏目列表调用,具体我不写了。

=====

看到这里,你是不是有什么想法?对了,可以参照这里改一下做二级滑动导航栏!哈哈,DEDE还是挺好用的。

你可能感兴趣的:(html,function,css,qq,测试,产品)