您现在的位置是:首页 > 教程 > dedecms教程dedecms教程
dede获取任意栏目N级列表链接树形菜单的方法
宛海2023-10-29 00:20:52dedecms教程已有人查阅
导读在DEDECMS里获取顶级栏目很简单,一句 {dede:channel}{/dede:channel} 即可搞定。但有时我们需要在任意页面获取任意顶级栏目下的二级和san级栏目列表的链接
在DEDECMS里获取顶级栏目很简单,一句 {dede:channel}{/dede:channel} 即可搞定。但有时我们需要在任意页面获取任意顶级栏目下的二级和san级栏目列表的链接, {dede:channel} 就无能为力了。注意,我说的是在“任意”(首页、封面、列表、文章等)页面调用“任意”二或san级栏目列表。
OK,一步步来,先第一个。(适用dedecmsV4,V5.X未测试。)感谢双赢朋友帮忙测试。原来的函数在某些主机上进行生成html操作会提示inc_channel_unit_functions.php出错,现已改正。大家可放心使用。
一、在任意页面获取某顶级栏目下的二级栏目列表
例如,我们要在首页或其他页面插入 产品展示 这个顶级栏目的下级栏目列表,
1、在 /include/inc_functions.php 之后的
?> 前加入以下代码:
3、伪静态的话请用以下代码:
这里其实是取得一个树形菜单,共两级,如要多级的话,请自行参照修改。
1、在 /include/inc_functions.php 之后的
?> 前加入以下代码:
3、产生的代码如下:
更新:
4、伪静态的话请用以下代码:
三、在任意页面获取顶级栏目和二级栏目列表
1、在 /include/inc_functions.php 之后的
?> 前加入以下代码:
加入第二点[二、在任意页面获取某顶级栏目下的二级栏目和san级栏目列表(树形菜单)]的两个函数,然后把第一个函数
2、在模板里用
3、你可举一反三做成N级栏目列表调用,具体我不写了。
看到这里,你是不是有什么想法?对了,可以参照这里改一下做二级滑动导航栏!
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="$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="/list-".$row->ID.".html">".$row->typename."</a></li>n ";
}
$dsql->Close();
return $linkList;
}
二、在任意页面获取某顶级栏目下的二级栏目和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);
$linkList .= "n<li><a href="$typelink"><b>".$row->typename."</b></a></li>nn";
$linkList .= getSonClass($row->ID);
}
$dsql->Close();
return $linkList;
}
//获得小类栏目链接
function getSonClass($parentid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("Select ID,typedir,typename From dede_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 .= "<li class="smallclass"><a href="$typelink">".$row->typename."</a></li>n";
}
return $linkList;
}
2、在模板里用
{dede:channel function=’getProductTree(2)’}{/dede:channel}
调用即可。这里getProductTree(2)中的 2 是产品展示的栏目ID。如果你的是其他的,请作相应修改。3、产生的代码如下:
<li><a href="/product/ac-dc/"><b>AC/DC开关电源</b></a></li>
<li class="smallclass"><a href="/product/ac-dc/1-way/">一路输出10W-350W</a></li>
<li class="smallclass"><a href="/product/ac-dc/2-way/">二路输出15W-200W</a></li>
<li class="smallclass"><a href="/product/ac-dc/3-way/">三路输出15W-200W</a></li>
<li class="smallclass"><a href="/product/ac-dc/4-way/">四路输出30W-200W</a></li>
<li><a href="/product/dc-dc/"><b>DC/DC开关电源</b></a></li>
<li class="smallclass"><a href="/product/dc-dc/1-way/">一路输出10W-200W</a></li>
<li class="smallclass"><a href="/product/dc-dc/2-way/">二路输出10W-150W</a></li>
<li class="smallclass"><a href="/product/dc-dc/3-way/">三路输出10W-150W</a></li>
<li class="smallclass"><a href="/product/dc-dc/4-way/">四路输出10W-150W</a></li>
在CSS里你就可以对 .smallclass 设置样式,如不同背景和缩进等。更新:
4、伪静态的话请用以下代码:
/*——————————————————
在任意页面获取某顶级栏目下的二级栏目和san级栏目列表 用于channel标记 (用于伪静态)
——————————————————*/
//获得大类栏目链接
function getProductTree($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())
{
$linkList .= "n<li><a href="/list-".$row->ID.".html"><b>".$row->typename."</b></a></li>nn";
$linkList .= getSonClass($row->ID);
}
$dsql->Close();
return $linkList;
}
//获得小类栏目链接
function getSonClass($parentid)
{
$linkList = "";
$dsql = new DedeSql(false);
$dsql->SetQuery("Select ID,typename From dede_arctype where reID=’$parentid’ order by sortrank");
$dsql->Execute($parentid);
while($row=$dsql->GetObject($parentid))
{
$linkList .= "<li class="smallclass"><a href="/list-".$row->ID.".html">".$row->typename."</a></li>n";
}
return $linkList;
}
最诱人的更新:三、在任意页面获取顶级栏目和二级栏目列表
1、在 /include/inc_functions.php 之后的
?> 前加入以下代码:
加入第二点[二、在任意页面获取某顶级栏目下的二级栏目和san级栏目列表(树形菜单)]的两个函数,然后把第一个函数
function getProductTree($typeid)
里的:
select ID,typedir,typename from dede_arctype where reID = ‘$typeid’ order by sortrank
改为:
select ID,typedir,typename from dede_arctype where reID = ’0′ order by sortrank
就是把 $typeid 改为 0 。2、在模板里用
{dede:channel function=’getProductTree()’}{/dede:channel}
调用即可。3、你可举一反三做成N级栏目列表调用,具体我不写了。
看到这里,你是不是有什么想法?对了,可以参照这里改一下做二级滑动导航栏!
本文标签:
很赞哦! ()
相关文章
随机图文
-
dedecms怎么更换空间,dedecms搬家的方法
做网站数据换空间是经常的事情,由于dede数据库跟空间是不再一起,所以一直让许多人dede搬家是一件十分头疼的事情,其实不然,dede搬家其实十分简单 -
织梦dedecms仿站视频教程建站入门到精通
简介:本教程汇集了网上诸多名站收费VIP视频教程,采集教程涵盖面广,从初级到高级。学习后可自主建站、仿站、调站,作出真正属于自己的风格。DEDECMS织梦 -
linux主机实现织梦dedecms的tags标签静态化
linux主机Apache Web Server环境搭建的DeDeCMS,要实现Tag伪静态,需要使用.htaccess设置Rewrite规则,具体实现请按如下步骤操作。 -
织梦后台实现会员动态显示投稿或评论时的ip地址的方法
一,在织梦后台系统设置.sql命令行工具中,运行下面的代码.修改数据库 dede的数据表前缀,要根据情况进行修改 ALTER TABLE `dede_me
留言与评论 (共有 条评论) |