如何获取织梦cms当前栏目的顶级栏目名称

藏色散人
发布: 2019-12-16 09:55:20
原创
1853 人浏览过

如何获取织梦cms当前栏目的顶级栏目名称

如何获取织梦cms当前栏目的顶级栏目名称?

在用织梦做一些项目时,时常会碰到需要在当前页面调用顶级栏目名称的时候,织梦默认{dede:field name='typename' /} 可以获取当前栏目页上一级栏目的名称,而不是当前栏目顶级栏目名称。

推荐学习:织梦cms

使用时一定要注意是不是需要修改查询语句表的前缀

下面拓展出一个方法来实现这个效果、:

在include/common.func.php的最下方加入:

//获取顶级栏目名 function GetTopTypename($id) { global $dsql; $row = $dsql->GetOne("SELECT typename,topid FROM dede_arctype WHERE id= $id"); if ($row['topid'] == '0') { return $row['typename']; } else { $row1 = $dsql->GetOne("SELECT typename FROM dede_arctype WHERE id= $row[topid]"); return $row1['typename']; } }
登录后复制

在文章页或者栏目列表页调用时,在所要调用 名称的位置加上下面这行代码即可实现。

{dede:field name='typeid' function="GetTopTypename(@me)" /}
登录后复制

在文章页中用下面这个方法来调用

{dede:field name='typeid' function="GetTopTypename(@me) /}
登录后复制

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

dedecms获取顶级栏目名称、二级栏目名称实现方法

今天做站的时候碰到一个问题,需要在二级、三级,甚至更多级,获取顶级栏目或者二级栏目名称。

现在和大家分享下最简单的实现方法。找到include/common.func.php文件,在里面加入下面这段代码:

//获取二级栏目名 function GetTopTypename($id) { global $dsql; $row = $dsql->GetOne("SELECT typename,reid FROM gsh_arctype WHERE id= $id"); if ($row['reid'] == '0') { return $row['typename']; } else { $row2 = $dsql->GetOne("SELECT typename FROM gsh_arctype WHERE id= $row[reid]"); return $row2['typename']; } }
登录后复制

然后在任意列表页、内容页需要调用名称的地方加入:

{dede:field.typeid fuction="GetToypename(@me)"/}
登录后复制

如果在dede标签里面,就用下面这句调用:

[field:typeid fuction="GetToypename(@me)"/]
登录后复制

上面这个方法是调用栏目的二级栏目名称,如果需要顶级栏目名称,只要将SQL里面的reid字段改成topid就可以了。另外记得将gsh_arctype前缀改成你数据库的前缀。

以上是如何获取织梦cms当前栏目的顶级栏目名称的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!