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級列表鏈接

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級列表鏈接

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還是挺好用的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章