温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

详解Dedecms各种形式的栏目调用标签,包括SQL调用方法

发布时间:2020-06-21 06:45:52 来源:网络 阅读:683 作者:gutaotao1989 栏目:开发技术

DedeCMS获取文档当前栏目所在目录链接URL


DedeCMS内容页调用当前栏目其实用下来是调用不出来的,{dede:field.typename/}是有效的,可是 {dede:field.typeurl/}却调不出文档当前栏目所在目录链接URL。查了下网上有网友提供了解决的办法,贴出来大家分享:


方法一:

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


方法二:

动手改装一下函数了,利用DEDECMS自定义函数的接口文件,我们在文章页中的标记把


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


这个放在内容页的模板中,把如下函数:


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系统内置函数


dedecms获取当前文档url地址的方法


{dede:field name='arcurl'/}

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

代码功能:父栏目及子栏目同时调用

使用说明……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}

 

网上搜集的栏目调用代码:

 

一、二、三级栏目调用

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

 

主栏目调用

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

 

在列表页和内容页调用顶级栏目名称方法

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


根据下级栏目获得顶级栏目名称的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}

 

怎么在首页调用dede子栏目

{dede:channel type='son' typeid='栏目ID'}

<a href="[field:typelink/]">[field:typename/]</a>

{/dede:channel}


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI