dede調用當前頂級欄目名稱、ID、url方法


使用dede時,經常會碰到需要調用當前頂級欄目名稱,而織夢默認{dede:field name='typename' /} 只可以獲取當前欄目頁上一級欄目的名稱,而不是當前欄目頂級欄目名稱。

 

在include/common.func.php的底部加入:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//獲取頂級欄目名
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' ];
     }
}

備注:若頂級欄目沒有綁定二級域名,所調用的字段應該是 sitepath 故代碼應如下所示: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//獲取頂級欄目url 
function  GetTopTypeurl( $id )
{
     global  $dsql ;
     $row  $dsql ->GetOne( "SELECT sitepath,topid FROM dede_arctype WHERE id= $id" );
     if  ( $row [ 'topid' ] ==  '0' )
     {
         return  $row [ 'sitepath' ];
     }
     else
     {
         $row1  $dsql ->GetOne( "SELECT sitepath FROM dede_arctype WHERE id= $row[topid]" );
         return  $row1 [ 'sitepath' ];
     }
}

頂級欄目其他字段調用的function 函數仿照上面所示書寫即可。

 

 

同理可得獲取頂級欄目url方法 (當頂級欄目綁定二級域名時調用的字段為“ siturl”) 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
function  GetTopTypeurl( $id )
{
     global  $dsql ;
     $row  $dsql ->GetOne( "SELECT siteurl,topid FROM dede_arctype WHERE id= $id" );
     if  ( $row [ 'topid' ] ==  '0' )
     {
         return  $row [ 'siteurl' ];
     }
     else
     {
         $row1  $dsql ->GetOne( "SELECT siteurl FROM dede_arctype WHERE id= $row[topid]" );
         return  $row1 [ 'siteurl' ];
     }
}

 

在文章頁或者欄目列表頁調用時,在所要調用欄目名稱的位置加上下面這行代碼即可實現。

{dede:field name='typeid' function="GetTopTypename(@me)" /}    頂級欄目名

{dede:field name='typeid' function="GetTopTypeurl(@me)" /}     頂級欄目url

 

dede調用頂級欄目ID 方法一:

{dede:field.typeid function="GetTopid(@me)"/} 聚模板首推這一方法,經過測試是可行的。

 

dede調用頂級欄目ID 方法二:

1、在所需要調用頂級欄目ID的地方,添加這段標簽語法

{dede:type}[feild:topid/]{/dede:type}

 

2、修改源文件,找到include目錄下的taglib目錄下的type.lib.php。

找到這條語句

1
2
$row  $dsql ->GetOne(“Select id,typename,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath
From `dede_arctype` where id=’ $typeid ’ “);

修改成為

1
2
$row  $dsql ->GetOne(“Select id,topid,typename,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath
From `dede_arctype` where id=’ $typeid ’ “);

在if(!is_array($row)) return ”;下一行添加

1
if $row [ 'topid' ]==0){ $row [ 'topid' ]= $row [ 'id' ];}

這樣,這條語句在頂級欄目還是子欄目,都可以調用了


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM