zoukankan      html  css  js  c++  java
  • 织梦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 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 name='typeid' function="GetTopTypename(@me)" /}

     

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

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

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

  • 相关阅读:
    javascript--Date
    PL/SQL的命令行窗口中执行脚本
    关于资产新增接口问题描述
    ORA-00600: internal error code, arguments: [kqludp2], [0x08D226918], [0], [], [], [], [], [], [], [], [], []
    Oracle 表空间扩容
    EBS 创建会计科目 小结
    EBS AP 创建会计科目失败
    EBS GL 日记账行“账户说明”段说明显示不全
    EBS 修改系统名称
    EBS 修改系统颜色
  • 原文地址:https://www.cnblogs.com/cbboys/p/3611194.html
Copyright © 2011-2022 走看看