溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

詳解Dedecms各種形式的欄目調(diào)用標簽,包括SQL調(diào)用方法

發(fā)布時間:2020-06-21 06:45:52 來源:網(wǎng)絡(luò) 閱讀:683 作者:gutaotao1989 欄目:開發(fā)技術(shù)

DedeCMS獲取文檔當前欄目所在目錄鏈接URL


DedeCMS內(nèi)容頁調(diào)用當前欄目其實用下來是調(diào)用不出來的,{dede:field.typename/}是有效的,可是 {dede:field.typeurl/}卻調(diào)不出文檔當前欄目所在目錄鏈接URL。查了下網(wǎng)上有網(wǎng)友提供了解決的辦法,貼出來大家分享:


方法一:

{dede:type typeid='0′ row=1}[field:typelink /]{/dede:type}


方法二:

動手改裝一下函數(shù)了,利用DEDECMS自定義函數(shù)的接口文件,我們在文章頁中的標記把


{dede:field.typeid function='typeurl_arc(@me)'/}


這個放在內(nèi)容頁的模板中,把如下函數(shù):


function typeurl_arc($typeid){

$typeurl = ";

$dsql = new DedeSql(false);

$row = $dsql ->GetOne("select typedir from dede_arctype where id=$typeid");

$typeurl = MfTypedir($row['typedir']);

return $typeurl;


放到extend.func.php里。


注:MfTypedir為dedecms系統(tǒng)內(nèi)置函數(shù)


dedecms獲取當前文檔url地址的方法


{dede:field name='arcurl'/}

====================================================================================

代碼功能:父欄目及子欄目同時調(diào)用

使用說明……typeid,row

如果[field:typedir/]中含有{cmspath}而使鏈接無效,請使用[field:typedir function='str_replace("{cmspath}","",@me)'/] 此標簽替換[field:typedir/]。

{dede:field name='typedir' runphp='yes'}

@me=str_replace("{cmspath}","",@me);

{/dede:field}

 

網(wǎng)上搜集的欄目調(diào)用代碼:

 

一、二、三級欄目調(diào)用

{dede:channelartlist typeid=top row=4}

<div class="cpmll">

<span><a href="{dede:field name='typeurl'/}">{dede:field name='typename'/}</a></span>

<ul>

{dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}

<li><a href='[field:typedir/]' target='_blank'>[field:typename/]</a></li>

{/dede:sql}

</ul>

</div>

{/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}


向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI