找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1183|回复: 0

[分享] 织梦DEDECMS文章、栏目页获取当前页面顶级栏目名称的方法

[复制链接]
发表于 2018-7-13 14:31:55 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
在用织梦做一些项目时,时常会碰到需要在当前页面调用顶级栏目名称的时候,织梦默认{dede:field name='typename' /} 可以获取当前栏目页上一级栏目的名称,而不是当前栏目顶级栏目名称。
下面拓展出一个方法来实现这个效果、:

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

  1. //获取顶级栏目名
  2. function GetTopTypename($id)
  3. {
  4. global $dsql;
  5. $row = $dsql->GetOne("SELECT typename,topid FROM dede_arctype WHERE id= $id");
  6. if ($row['topid'] == '0')
  7. {
  8. return $row['typename'];
  9. }
  10. else
  11. {
  12. $row1 = $dsql->GetOne("SELECT typename FROM dede_arctype WHERE id= $row[topid]");
  13. return $row1['typename'];
  14. }
  15. }
复制代码


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

{dede:field name='typeid' function="GetTopTypename(@me)" /}



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

{dede:field name='typeid' function="GetTopTypename(@me) /}
===================================
dedecms获取顶级栏目名称、二级栏目名称实现方法

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

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

  1. //获取二级栏目名
  2. function GetTopTypename($id)
  3. {
  4. global $dsql;
  5. $row = $dsql->GetOne("SELECT typename,reid FROM gsh_arctype WHERE id= $id");
  6. if ($row['reid'] == '0')
  7. {
  8. return $row['typename'];
  9. }
  10. else
  11. {
  12. $row2 = $dsql->GetOne("SELECT typename FROM gsh_arctype WHERE id= $row[reid]");
  13. return $row2['typename'];
  14. }
  15. }
复制代码


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

{dede:field.typeid fuction="GetToypename(@me)"/}

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

[field:typeid fuction="GetToypename(@me)"/]

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

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-12-23 22:25 , Processed in 0.039170 second(s), 9 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表