①:通過dede調(diào)用二級欄目大家都會(huì)調(diào)用,但要調(diào)用三級欄目,就有點(diǎn)麻煩了,如下樣式的三級欄目dede如何調(diào)用呢?如下:
----------------------------------------A級主欄目
+頂級欄目
+二級欄目
+三級欄目(A)
+三級欄目(B)
+三級欄目(C)
+二級欄目
+三級欄目(D)
+三級欄目(E)
+三級欄目(F)
----------------------------------------B級主欄目
+頂級欄目
+二級欄目(G)
+二級欄目(H)
+二級欄目(I)
{dede:channelartlist typeid=6 row=4} (注:這是頂級欄目id)
{dede:field name='typename'/} (注:這是二級欄目名稱)
{dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}
[field:typename/]
(注:這是三級欄目的靜態(tài)路徑和欄目名稱)
{/dede:sql}
{/dede:channelartlist}
因?yàn)閇field:typedir /]在數(shù)據(jù)庫存儲的路徑包括{cmspath}這個(gè)字符串,所以我們必須處理一下,就用到織夢(dedecms)自帶的cn_substr這個(gè)系統(tǒng)函數(shù),這里簡要說一下這個(gè)函數(shù)的參數(shù),@me是當(dāng)前字段值,也就是取出的[field:typedir /]這個(gè)值,200和9表示從第9個(gè)字符位置( (不包括這個(gè)字符))開始截取200個(gè)字符。
{dede:channelartlist typeid='1'}
<span><a href="{dede:field name='typeurl'/}">{dede:field name='typename'/}</a></span>
{dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,10'}
<li><a href='[field:typedir/]' target='_blank'>[field:typename/]</a></li>
{/dede:sql}
{/dede:channelartlist}
{dede:channelartlist typeid='1'}
<li><a href='{dede:field name='typeurl'/}'>{dede:field name='typename'/}</a></li>
{dede:sql sql='Select * from dede_arctype where reid=~id~'}
<li><a href='[field:typedir function='str_replace("{cmspath}","",@me)'/]'>[field:typename/]</a></li>
{/dede:sql}
{/dede:channelartlist}
主欄目調(diào)用
{dede:channelartlist typeid=top row=''}
<li><a href="{dede:field name='typeurl'/}">{dede:field name='typename'/}</a>
<ul>
{dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}
[field:array runphp='yes']@me = (!empty(@me['reid']) ? "" : "<li><a href='{@me['typedir']}' target='_blank'>{@me['typename']}</a></li>"); [/field:array]
{/dede:sql}
</ul>
</li>
{/dede:channelartlist}
在列表頁和內(nèi)容頁調(diào)用頂級欄目名稱方法
{dede:field.typeid runphp='yes' function="GetTopid(@me)"}
$dsql = new DedeSql(false);
$a="SELECT typename FROM dede_arctype where id=@me";
$arcRow = $dsql->GetOne($a);
@me=$arcRow[typename];{/dede:field.typeid}
根據(jù)下級欄目獲得頂級欄目名稱的SQL語句
{dede:field.typeid runphp='yes'}$ID = @me; $sql = "SELECT * FROM `dede_arctype` WHERE id=$ID";$query = mysql_query($sql);$row=mysql_fetch_array($query); $relID = "$row[reid]"; if($relID == 0) {@me = $row[typename];}else{$sql = "SELECT `typename` FROM `dede_arctype` WHERE id=$relID";$query = mysql_query($sql);$row=mysql_fetch_array($query); @me = $row[typename];}{/dede:field.typeid}
怎么在首頁調(diào)用dede子欄目
{dede:channel type='son' typeid='欄目ID'}
<a href="[field:typelink/]">[field:typename/]</a>
{/dede:channel}