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

2021-01-16 00:00:00


今天在群里看到有位朋友需要实现中英文栏目名字的功能(如下图),下面我们就来看看强大的织梦CMS怎么实现吧! 



首先给数据库中的dede_arctype表中增加一个字段



添加后的效果如上图,具体的添加办法再次就不详述了。其中typenameng就是我增加的字段,名称有点长,当然你也可以改为自己乐意的名称,这个不伤大雅。 
再找到dede emplets目录下的catalog_edit.htm 
  
找到 
栏目名称: 
 
 
下面添加栏目英文名称: 
 
 
最后我们在打开 dedecatalog_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'}
  • [field:typename/][field:typenameng/]
  • {/dede:channel} 
      
    则还要修改一个文件,找到include aglibchannel.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 aglibchannel.lib.php140行 $linkOkstr = str_replace("~typename~",$row['typename'],$linkOkstr);下面添加 
    $linkOkstr = str_replace("~typenameeng~",$row['typenameeng'],$linkOkstr);即可。
     
    文章标签:

      本站内文章部分来自于用户投稿或者编辑整理,文章其版权均归原作者及其网站所有。

    上一篇:织梦dedecms上传图片出现ERROR:C···

    下一篇:织梦dedecms修改文章标题-2级栏目-1···