dede如何实现嵌套li加currentstyle的二级菜单

在夕阳西下时,伴着如夜晚霞,刮起来美丽的秋风,金黄的叶子从树上落下来,像一只只美丽的蝴蝶,翩翩起舞格外美丽。树下,一个个活泼可爱的小朋友正在捡树叶,放在收集本子里,把美丽的秋天永远珍藏。
dede实现嵌套li加currentstyle的二级菜单非常麻烦,所以官方之前的版本也使用了js来实现,而且为此还hardcode了一下编码到标签库里面,具体见 \include\taglib\channel.lib.php 
line100
//检查是否有子栏目,并返回rel提示(用于二级菜单)

及 line130

$row['rel'] = " rel='dropmenu{$row['id']}'";

可见,如果需要二级菜单加当前样式,那么头部


  1. <ul>  
  2.         <li><a rel="nofollow noopener noreferrer" href='{dede:global.cfg_cmsurl/}/'>  
  3.             <span class="cn">首页</span>  
  4.             <span class="en">Home</span>  
  5.         </a></li>  
  6.         {dede:channel type='top' row='10' currentstyle='<li class="current"><a rel="nofollow noopener noreferrer" href="~typelink~" ~rel~>#<span class="cn">~typename~</span><span class="en">~dirName~</span></a></li>'  
  7.         }  
  8.         <li>  
  9.             <a rel="nofollow noopener noreferrer" href='[field:typeurl/]' [field:rel/]>  
  10.                 <span class="cn">[field:typename/]</span>  
  11.                 <span class="en">[field:typedir runphp='yes' commet="获得最后目录名,英文"]  
  12.                     $l=split("/", @me);  
  13.                     @me=array_pop($l);  
  14.                 [/field:typedir]</span>  
  15.             </a>  
  16.         </li>  
  17.         {/dede:channel}  
  18.     </ul>  

rel的属性是必须的

 

而且在底部
 

{dede:channelartlist typeid='top'}  
    <ul id="dropmenu{dede:field.typeid/}">  
    {dede:channel type='son' noself='yes'}  
        <li><a rel="nofollow noopener noreferrer" href="[field:typelink/]">[field:typename/]</a></li>  
    {/dede:channel}  
    </ul>  
{/dede:channelartlist}  


dropmenu的关键字也是必须的。

 

剩下的就是css和js的工作了。

本文dede如何实现嵌套li加currentstyle的二级菜单到此结束。不要忘记为自己,为爱自己的人而活……小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
织梦后台文档列表添加复制文档功能支持所有模型

织梦无法上传ico图标格式文件的如何解决方法

dedecms如何实现任意页面调用当前会员信息的方

织梦dede:tag调用指定多个栏目的TAG标签

织梦栏目列表按附加表自定义字段排序