织梦实现嵌套li加currentstyle的二级菜单

相关案例演示
织梦dedecms实现嵌套li加currentstyle的二级菜单非常麻烦,所以官方之前的版本也使用了js来实现,而且为此还hardcode了一下编码到标签库里面,具体见 \include\taglib\channel.lib.php 
line100
//检查是否有子栏目,并返回rel提示(用于二级菜单)

及 line130

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

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

<ul>  
        <li><a href='{dede:global.cfg_cmsurl/}/'>  
            <span class="cn">首页</span>  
            <span class="en">Home</span>  
        </a></li>  
        {dede:channel type='top' row='10' currentstyle='<li class="current"><a href="~typelink~" ~rel~>#<span class="cn">~typename~</span><span class="en">~dirName~</span></a></li>'  
        }  
        <li>  
            <a href='[field:typeurl/]' [field:rel/]>  
                <span class="cn">[field:typename/]</span>  
                <span class="en">[field:typedir runphp='yes' commet="获得最后目录名,英文"]  
                    $l=split("/", @me);  
                    @me=array_pop($l);  
                [/field:typedir]</span>  
            </a>  
        </li>  
        {/dede:channel}  
    </ul>  


rel的属性是必须的

 

而且在底部
 

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

dropmenu的关键字也是必须的。

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


免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。


来源:网友投稿 关注: 时间:2020-03-02 08:35
首先声明,只要是我们的vip会员所有源码均可以免费下载,不做任何限制(了解更多)
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品织梦源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站织梦程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ进行交流。
相关织梦教程
QQ在线咨询