前端很多时候需要直接获取一个栏目的相关信息,获取在某个页面上获取顶级或者上一级栏目的相关信息,这样我们可以自己写个自定义方法来实现。
打开 /include/extend.func.php 在最下面添加
/**
 *  获取顶级栏目相关信息
 *
 * @access    public
 * @param     string  $tid  栏目id
 * @param     string  $field 栏目字段
 * @return    string
 */
if ( ! function_exists('getToptype'))
{
function getToptype($tid,$field)
{
global $dsql,$cfg_Cs;
if(!is_array($cfg_Cs))
{
require_once(DEDEDATA."/cache/inc_catalog_base.inc");
}
if(!isset($cfg_Cs[$tid][0]) || $cfg_Cs[$tid][0]==0)
{
$topid = $tid;
}
else
{
$topid = GetTopid($cfg_Cs[$tid][0]);
}
$row = $dsql->GetOne("SELECT * FROM `dede_arctype` WHERE id=$topid");
if($field=='id') return $topid;
if($field=='typeurl' || $field=='typelink') return GetOneTypeUrlA($row);
return $row[$field];
}
}
/**
 *  获取当前栏目相关信息
 *
 * @access    public
 * @param     string  $tid  栏目id
 * @param     string  $field 栏目字段
 * @return    string
 */
if ( ! function_exists('getCurtype'))
{
function getCurtype($tid,$field)
{
global $dsql;
$row = $dsql->GetOne("SELECT * FROM `dede_arctype` WHERE id=$tid");
if($field=='id') return $tid;
if($field=='typeurl' || $field=='typelink') return GetOneTypeUrlA($row);
return $row[$field];
}
}
/**
 *  获取上级栏目相关信息
 *
 * @access    public
 * @param     string  $tid  栏目id
 * @param     string  $field 栏目字段
 * @return    string
 */
if ( ! function_exists('getRetype'))
{
function getRetype($tid,$field)
{
global $dsql;
$typeid = $tid;
$query = "SELECT reid FROM `dede_arctype` where id = $typeid";
$rs = $dsql->GetOne($query);
$reid = $rs['reid']; 
$query2 = "SELECT * FROM `dede_arctype` where id = $reid";
$row = $dsql->GetOne($query2);
if($field=='id') return $row['id'];
if($field=='typeurl' || $field=='typelink') return GetOneTypeUrlA($row);
return $row[$field];
}
}
模板里调用标签写法
需要哪个字段,就对应的填上字段名即可
  • 获取顶级栏目相关信息
{dede:field.typeid function=getToptype(@me,typename)/}
  • 获取当前栏目相关信息
{dede:field.typeid function=getCurtype(@me,typename)/}
  • 获取上级栏目相关信息
{dede:field.typeid function=getRetype(@me,typename)/}
不喜欢添加自定义方法的同学可以试试这样
{dede:field.typeid runphp=yes}global $dsql;$row = $dsql->GetOne("SELECT * FROM dede_arctype WHERE [email protected]");$reid = "$row[reid]"; $topid = "$row[topid]";if($reid == 0) @me = $row[content];else $row = $dsql->GetOne("SELECT * FROM dede_arctype WHERE id=$topid");@me = $row[content];{/dede:field.typeid}
获取顶级的是topid
获取上级的是reid
  • 案例
栏目列表页加入【全部】按钮链接,并且高亮
<ul>
<li><a href="{dede:field.typeid runphp=yes}global $dsql;$row = $dsql->GetOne("SELECT * FROM dede_arctype WHERE [email protected]");$reid = "$row[reid]";$topid = "$row[topid]";if($reid == 0) @me = GetOneTypeUrlA($row);else $row = $dsql->GetOne("SELECT * FROM dede_arctype WHERE id=$topid");@me = GetOneTypeUrlA($row);{/dede:field.typeid}"{dede:field name=topid runphp=yes}if(@me)@me=''; else @me=' class="on"';{/dede:field}>全部</a></li>
{dede:channel type='son' row='10' currentstyle="<li><a href='~typelink~' class='on'>~typename~</a></li>"}
<li><a href='[field:typeurl/]' [field:rel/]>[field:typename/]</a></li>
{/dede:channel}
</ul>