DedeCMS在栏目加一个字段实现中英文导航功能


今天在群里看到有位朋友需要实现中英文栏目名字的功能(如下图),下面我们就来看看强大的织梦CMS怎么实现吧!  
  首先给数据库中的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.php140行 $linkOkstr = str_replace(“~typename~”,$row[‘typename’],$linkOkstr);下面添加 $linkOkstr = str_replace(“~typenameeng~”,$row[‘typenameeng’],$linkOkstr);即可。