首页 > CMS > 织梦DEDE > 正文

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

2024-07-12 08:27:59
字体:
来源:转载
供稿:网友
织梦dedecms文章、栏目页获取当前页面顶级栏目名称的方法   在用织梦做一些项目时,时常会碰到需要在当前页面调用顶级栏目名称的时候,织梦默认{dede:field name='typename' /} 可以获取当前栏目页上一级栏目的名称,而不是当前栏目顶级栏目名称。   下面拓展出一个方法来实现这个效果、:   在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 dede_arctype WHERE id= $id");  if ($row['reid'] == '0')  {  return $row['typename'];  }  else  {  $row2 = $dsql->GetOne("SELECT typename FROM dede_arctype WHERE id= $row[reid]");  return $row2['typename'];  }  }       然后在任意列表页、内容页需要调用名称的地方加入:   {dede:field.typeid fuction="GetToypename(@me)"/}   如果在dede标签里面,就用下面这句调用:   [field:typeid fuction="GetToypename(@me)"/]   www.dede58.com上面这个方法是调用栏目的二级栏目名称,如果需要顶级栏目名称,只要将SQL里面的reid字段改成topid就可以了。另外记得将dede_arctype前缀改成你数据库的前缀。  
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表