织梦栏目mysql调用_织梦dedecms子栏目获取顶级栏目名称和链接方法

dedecms5.7获取顶级栏目名称的标签

下面是调用顶级栏目名称的方法:

方法一:

{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:field.title runphp='yes'}

list($toptype,$sontype)=split('/',@me);@me=$toptype;

{/dede:field.title}

方法三:

{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]"; $topID="$row[topid]";

if($relID == 0) {@me = $row[typename];}

else{$sql = "SELECT `typename` FROM `dede_arctype` WHERE id=$topID";

$query = mysql_query($sql);$row=mysql_fetch_array($query);

@me = $row[typename];}{/dede:field.typeid}

方法四(推荐):

打开include/helpers/extend.helper.php,添加一个函数:

/**

* 获取指定栏目id的顶级栏目的名称

*

* @return string

*/

if ( ! function_exists('getTopChannelName'))

{

function getTopChannelName($id) {

global $dsql;

$typeinfo = $dsql->GetOne("SELECT * FROM `dede_arctype` WHERE id='{$id}'");

if($typeinfo['reid']==0) return $typeinfo['typename'];

else return getTopChannelName($typeinfo['reid']);

}

}

在列表页这么使用:{dede:field name='id'  function='getTopChannelName(@me)'/}

在内容页这么使用:{dede:field name='typeid'  function='getTopChannelName(@me)'/}

附带获取顶级栏目的url:

打开include/helpers/extend.helper.php,添加一个函数:

/**

*  获取指定栏目id的顶级栏目的url

*

* @return string

*/

if ( ! function_exists('getTopChannelUrl'))

{

function getTopChannelUrl($id) {

global $dsql;

$typeinfo = $dsql->GetOne("SELECT * FROM `dede_arctype` WHERE id='{$id}'");

if($typeinfo['reid']==0) return GetOneTypeUrlA($typeinfo);

else return getTopChannelUrl($typeinfo['reid']);

}

}

使用方法同上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值