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

    现在和大家分享下最简单的实现方法。找到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 function="GetTopTypename(@me)"/}   

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

[field:typeid function="GetTopTypename(@me)"/]   

    上面这个方法是调用栏目的二级栏目名称,如果需要顶级栏目名称,只要将SQL里面的reid字段改成topid就可以了。

    注意:如果你的表前缀不是默认的dede_,记得将dede_arctype前缀改成你数据库的前缀。