-
Dedecms 实现带 CurrentStyle 的二级菜单嵌套 LI
- 时间:2025-03-30 08:25:42 来源: 人气:0
在使用Dedecms实现带有currentstyle的二级菜单时,可能会遇到一些复杂的情况。这是因为官方之前的版本中采用了JavaScript来处理这个问题,并且在标签库中硬编码了一些特定的功能。具体可以参考文件路径:`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>
此外,在页面底部还需要定义如下内容以支持二级菜单的显示:
{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}
完成以上步骤后,剩下的工作就是通过CSS和JavaScript来美化和控制菜单的行为。例如,可以通过CSS设置悬停效果或激活状态下的样式,同时利用JavaScript增强用户体验,如实现下拉菜单的动态展示等。
这样,一个功能完善的、具有currentstyle样式的二级菜单就可以顺利实现了。
相关文章
-
在网站建设与维护的过程中,优化代码结构和功能是提升网站性能的重要步骤。本文将介绍如何通过自定义函数实现文章删除时自动清理相关资源的功能,从而提高系统的整洁性和存储效率。以下是具体的操作步骤及代码实现。首先, 在 `/include` 目录下创建一个名为 `extend.func.php` 的文件...2025-03-31
-
在进行图片上传操作时,用户可能会遇到302错误以及带有ERROR提示的图片上传失败问题。这些问题可能由多种原因引发,因此本文将对这些情况进行整理,以帮助大家更有效地定位并解决问题。 第一种情况:图片文件本身损坏。 这种情况会导致系统返回ERROR错误提示,不过发生概率较低。如果怀疑是图片损坏导致的...2025-03-31
-
如果您正在寻找一种高效的方法来使用Dedecms模板搭建网站或论坛,那么本文将为您提供详尽的指导。从模板解压到最终完成配置,每一步都将清晰呈现,帮助您快速掌握整个流程。 第一步:解压Dedecms模板 将下载的Dedecms模板文件解压出来,确保所有文件完整无误。如下图所示: 第二步:获取D...2025-03-31
-
Dedecms Dede 附加表自定义字段与主表文章关联方法
在使用DedeCMS开发装修网站时,设计师和设计作品之间的关联是一个重要的功能需求。通常情况下,文章(作品)的内容部分存储在主表dede_addonarticle中,而自定义字段则存储在附加表dede_archives中。为了实现这一功能,可以采用以下两种方法。 ① 根据发布人调用相关文章; ...2025-03-31