POST TIME:2018-08-09 00:59
在DEDECMS里獲取頂級欄目很簡單,一句 {dede:channel}{/dede:channel} 即可搞定。但有時我們需要在任意頁面獲取任意頂級欄目下的二級和san級欄目列表的鏈接, {dede:channel} 就無能為力了。注意,我說的是在“任意”(首頁、封面、列表、文章等)頁面調(diào)用“任意”二或san級欄目列表。
OK,一步步來,先第一個。(適用dedecmsV4,V5.X未測試。)
感謝雙贏朋友幫忙測試。原來的函數(shù)在某些主機上進行生成html操作會提示 inc_channel_unit_functions.php 出錯,現(xiàn)已改正。大家可放心使用。
一、在任意頁面獲取某頂級欄目下的二級欄目列表
例如,我們要在首頁或其他頁面插入 產(chǎn)品展示 這個頂級欄目的下級欄目列表,
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}
調(diào)用即可。這里getProductClass(2)中的 2 是產(chǎn)品展示的欄目ID。如果你的是其他的,請作相應(yīng)修改。
3、效果如下:
4、偽靜態(tài)的話請用以下代碼:
//在任意頁面獲取某頂級欄目下的二級欄目列表 用于channel標記 $typeid為頂級欄目ID (用于偽靜態(tài))
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;
}
(DEDECMS全站偽靜態(tài)請看這里:DEDECMS全站(首頁、列表、文章頁)偽靜態(tài)詳細教程
)
二、在任意頁面獲取某頂級欄目下的二級欄目和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}
調(diào)用即可。這里getProductTree(2)中的 2 是產(chǎn)品展示的欄目ID。如果你的是其他的,請作相應(yīng)修改。
3、效果如下:
4、產(chǎn)生的代碼如下:
<li><a href="/product/ac-dc/"><b>AC/DC開關(guān)電源</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開關(guān)電源</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 設(shè)置樣式,如不同背景和縮進等。
更新:
5、偽靜態(tài)的話請用以下代碼:
/*——————————————————
在任意頁面獲取某頂級欄目下的二級欄目和san級欄目列表 用于channel標記 (用于偽靜態(tài))
——————————————————*/
//獲得大類欄目鏈接
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;
}
(DEDE全站偽靜態(tài)請看這里:DEDECMS全站(首頁、列表、文章頁)偽靜態(tài)詳細教程
)
最誘人的更新:
三、在任意頁面獲取頂級欄目和二級欄目列表
1、在 /include/inc_functions.php 最后的 ?> 前加入以下代碼:
加入第二點[二、在任意頁面獲取某頂級欄目下的二級欄目和san級欄目列表(樹形菜單)]的兩個函數(shù),然后把第一個函數(shù) 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} 調(diào)用即可。
3、你可舉一反三做成N級欄目列表調(diào)用,具體我不寫了。
=====
看到這里,你是不是有什么想法?對了,可以參照這里改一下做二級滑動導航欄!