在用织梦做一些项目时,时常会碰到需要在当前页面调用顶级栏目名称的时候,织梦默认{dede:field name='typename' /} 可以获取当前栏目页上一级栏目的名称,而不是当前栏目顶级栏目名称。
使用时一定要注意是不是需要修改查询语句表的前缀
下面拓展出一个方法来实现这个效果、:
在include/common.func.php的最下方加入:
02 |
function GetTopTypename($ id ) |
05 |
$row = $dsql->GetOne( "SELECT typename,topid FROM dede_arctype WHERE id= $id" ); |
06 |
if ($row[ 'topid' ] == '0' ) |
08 |
return $row[ 'typename' ]; |
12 |
$row1 = $dsql->GetOne( "SELECT typename FROM dede_arctype WHERE id= $row[topid]" ); |
13 |
return $row1[ 'typename' ]; |
|
在文章页或者栏目列表页调用时,在所要调用 名称的位置加上下面这行代码即可实现。
1 |
{dede:field name= 'typeid' function = "GetTopTypename(@me)" /} |
|
在文章页中用下面这个方法来调用
1 |
{dede:field name= 'typeid' function ="GetTopTypename(@me) /} |
|
===================================
dedecms获取顶级栏目名称、二级栏目名称实现方法
今天织梦云做站的时候碰到一个问题,需要在二级、三级,甚至更多级,获取顶级栏目或者二级栏目名称。
现在和大家分享下最简单的实现方法。找到include/common.func.php文件,在里面加入下面这段代码:
02 |
function GetTopTypename($ id ) |
05 |
$row = $dsql->GetOne( "SELECT typename,reid FROM gsh_arctype WHERE id= $id" ); |
06 |
if ($row[ 'reid' ] == '0' ) |
08 |
return $row[ 'typename' ]; |
12 |
$row2 = $dsql->GetOne( "SELECT typename FROM gsh_arctype WHERE id= $row[reid]" ); |
13 |
return $row2[ 'typename' ]; |
|
然后在任意列表页、内容页需要调用名称的地方加入:
1 |
{dede:field.typeid fuction= "GetToypename(@me)" /} |
|
如果在dede标签里面,就用下面这句调用:
1 |
[field:typeid fuction= "GetToypename(@me)" /] |
|
上面这个方法是调用栏目的二级栏目名称,如果需要顶级栏目名称,只要将SQL里面的reid字段改成topid就可以了。另外记得将gsh_arctype前缀改成你数据库的前缀。