這篇文章主要介紹了織夢DedeCMS在實現中英文導航功能方法步驟,本文給出詳細的操作步驟和相關實現代碼,需要的朋友可以參考下
今天在群裡看到有位朋友需要實現中英文欄目名字的功能(如),下面我們就來看看強大的織夢CMS怎麼實現吧!
dedecms模板下載地址: www.php.cn/xiazai/code/dedecms
首先給資料庫中的dede_arctype表中增加一個欄位,前面的表首碼是你的網站的名,並不一定是dede_
添加後的效果如,具體的添加辦法再次就不詳述了。其中typenameng就是我增加的欄位,名稱有點長,當然你也可以改為自己樂意的名稱,這個不傷大雅。
再找到dede\templets目錄下的catalog_edit.htm
找到
代碼如下:
<tr> <td class='bline' height="26" style="padding-left:10px;"><font color='red'>欄目名稱:</font></td> <td class='bline'><input name="typename" type="text" id="typename" size="30" value="<?php echo $myrow['typename']?>" class="iptxt" /></td> </tr>
下面添加
代碼如下:
<tr> <td class='bline' height="26" style="padding-left:10px;">欄目英文名稱:</td> <td class='bline'> <input name="typenameng" type="text" id="typenameng" size="30" value="<?php echo $myrow['typenameng']?>" class="iptxt" /></td></tr>
最後我們在開啟 dede\catalog_edit.php
找到
代碼如下:
$upquery = "UPDATE `#分隔字元@arctype` SET issend='$issend', sortrank='$sortrank', typename='$typename', typenameng='$typenameng', typedir='$typedir', isdefault='$isdefault', defaultname='$defaultname',
增加紅色的部分,分隔字元3個字自行去掉,至此就添加完成了。
調用方式 :
{dede:field name='typenameng'/}
想要在channel 中使用,例如
代碼如下:
{dede:channel type='son' row='10' typeid='1'} <li><a href='[field:typeurl/]'>[field:typename/][field:typenameng/]</a></li>{/dede:channel}
則還要修改一個檔案,找到include\taglib\channel.lib.php
第一處:
代碼如下:
if($type=='top') { $sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath From `#分隔字元@arctype` WHERE reid=0 And ishidden<>1 order by sortrank asc limit 0, $line "; } else if($type=='son') { if($typeid==0) return ''; $sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath From `#分隔字元@arctype` WHERE reid='$typeid' And ishidden<>1 order by sortrank asc limit 0, $line "; } else if($type=='self') { if($reid==0) return ''; $sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath FROM `#分隔字元@arctype` WHERE reid='$reid' And ishidden<>1 order by sortrank asc limit 0, $line "; }
第二處:
代碼如下:
//如果用子欄目模式,當沒有子欄目時顯示同級欄目 if($type=='son' && $reid!=0 && $totalRow==0) { $sql = "SELECT id,typename,typenameng,typedir,isdefault,ispart,defaultname,namerule2,moresite,siteurl,sitepath FROM `#分隔字元@arctype` WHERE reid='$reid' And ishidden<>1 order by sortrank asc limit 0, $line "; $dsql->SetQuery($sql); $dsql->Execute(); }
增加查詢欄位就可以在channel中使用了,還有type,channelartlist等標籤頁是在相應的lib類中添加查詢的欄位,在此限於篇幅就不錯詳細的敘述了。
//處理同級欄目中,當前欄目的樣式。currentstyle中的調用,include\taglib\channel.lib.php 140行 $linkOkstr = str_replace("~typename~",$row['typename'],$linkOkstr);下面添加
$linkOkstr = str_replace("~typenameeng~",$row['typenameeng'],$linkOkstr);即可。