首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

原生js实现树形菜单

基础概念

树形菜单是一种常见的用户界面元素,用于展示层次结构的数据。每个节点可以有多个子节点,通常以嵌套列表的形式呈现。原生JavaScript实现树形菜单意味着不依赖任何第三方库,仅使用JavaScript、HTML和CSS来完成。

相关优势

  1. 性能优化:原生实现避免了第三方库的额外开销,有助于提高页面加载速度。
  2. 灵活性:可以根据具体需求定制菜单的行为和样式。
  3. 学习价值:通过原生实现,可以深入理解DOM操作和事件处理机制。

类型

  • 静态树形菜单:数据在HTML中预先定义好,JavaScript仅用于交互。
  • 动态树形菜单:数据通过JavaScript动态生成,适用于数据量较大或需要频繁更新的场景。

应用场景

  • 文件管理系统:展示文件夹和文件的层次结构。
  • 组织架构图:展示公司或团队的层级关系。
  • 导航系统:提供多层次的网站导航。

实现示例

以下是一个简单的静态树形菜单的实现示例:

HTML

代码语言:txt
复制
<ul id="treeMenu">
    <li>
        <span class="node">Node 1</span>
        <ul>
            <li><span class="node">Node 1.1</span></li>
            <li><span class="node">Node 1.2</span></li>
        </ul>
    </li>
    <li>
        <span class="node">Node 2</span>
        <ul>
            <li><span class="node">Node 2.1</span></li>
            <li><span class="node">Node 2.2</span>
                <ul>
                    <li><span class="node">Node 2.2.1</span></li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

CSS

代码语言:txt
复制
#treeMenu ul {
    display: none;
    list-style-type: none;
    padding-left: 20px;
}

#treeMenu .node {
    cursor: pointer;
}

JavaScript

代码语言:txt
复制
document.addEventListener('DOMContentLoaded', function() {
    const nodes = document.querySelectorAll('.node');

    nodes.forEach(node => {
        node.addEventListener('click', function(event) {
            event.stopPropagation();
            const subMenu = this.nextElementSibling;
            if (subMenu && subMenu.tagName === 'UL') {
                subMenu.style.display = subMenu.style.display === 'block' ? 'none' : 'block';
            }
        });
    });
});

可能遇到的问题及解决方法

问题1:子菜单无法正确展开/折叠

原因:可能是事件监听器没有正确绑定,或者CSS样式设置有误。

解决方法

  • 确保每个节点都有正确的事件监听器。
  • 检查CSS样式,确保display属性正确切换。

问题2:点击事件冒泡导致意外行为

原因:事件冒泡可能导致父节点的事件被触发。

解决方法

  • 使用event.stopPropagation()阻止事件冒泡。

问题3:动态加载数据时菜单显示异常

原因:动态生成的内容可能没有绑定相应的事件监听器。

解决方法

  • 在数据加载完成后,重新绑定事件监听器或使用事件委托机制。

通过以上步骤和示例代码,可以实现一个基本的树形菜单,并解决常见的实现问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

zTree实现树形结构菜单

文章目录 一、简介 二、前端渲染效果 三、实现步骤 1、数据库表结构 2、引入zTree插件 3、树形结构实体类SysModule 4、表示层代码 5、js渲染部分 1、树初始化配置 2、加载数据树...控制器关键代码 5、业务逻辑层代码: 6、数据访问层代码: 四、碰到的bug及解决方案 1、指定结点选中无效 2、mybatis多对多关系的处理较为麻烦 一、简介 zTree 是一个依靠 jQuery 实现的多功能...二、前端渲染效果 三、实现步骤 1、数据库表结构 2、引入zTree插件 <link rel="stylesheet" href="/ccms/commons/jslib/ztreeV3.5.15..."> <script type="text/javascript" src="/ccms/commons/jslib/js-gmxt-define/ztreeTool.js"> 3、树形结构实体类SysModule 省略get和set方法 public class SysModule { /**模板编码*/ private String moduleCode

5.5K40
  • JAVA中怎样实现树形菜单

    这篇文中,我一共会用两种方式来实现目录树的数据结构,两种写法逻辑是一样的,只是一种适合新手理解,一种看着简单明了但是对于小白不是很好理解。...就是在实际开发过程中,总会遇到菜单,或则是权限,这个时候就涉及到后端返回数据给前端的时候,不能一个集合把数据一股脑的全部扔给前端,总要把数据整理好,做成像书目录一样的结构返回给前端。...就像以下图示一样 二、目录树结构实现写法 1、准备阶段 ①创建数据表 PS:如果是练习可以不用创建数据库,数据全部通过java代码来创建也可以 sql复制代码CREATE TABLE permission_directory...', menu_level int(11) NOT NULL COMMENT '菜单等级', route varchar(255) NOT NULL COMMENT '路由', PRIMARY KEY...@MyAnnotation("用于存储当前目录下面的全部子集") private List authMenuList; } 2、逻辑代码实现

    15010

    非递归实现树形下拉菜单

    非递归实现树形下拉菜单 博主 默语带您 Go to New World....好的,我会更详细地讲解 非递归实现树形下拉菜单 的完整思路和代码,同时为每一部分都加上清晰的注释,让初学者也能看懂。这次我们会以逐步实现的方式讲解每一步的逻辑。...非递归实现树形下拉菜单 什么是非递归实现? 在递归中,函数会自己调用自己。非递归实现是用 队列(Queue) 或 栈(Stack) 来替代函数调用栈,从而手动管理需要处理的数据,逐步完成任务。...实现步骤(以队列方式为例) 1....完整代码(队列实现) import java.util.*; public class CategoryTreeBuilder { /** * 构建树形结构(非递归方式,使用队列实现

    9210

    动态加载的树形菜单

    动态加载的树形菜单 开发工具与关键技术:MVC 树形菜单 作者:盘洪源 撰写时间:2019年6月2日星期天 在做到页面需要做到树形菜单,而且还是动态从数据库加载数据的,就是树形菜单的节点由数据库的数据来填充...首先一开始是这个数据库的设置,这个数据库的设置很重要,一开始想着这个树形菜单可以无限级的循坏下去,这得建多少个表啊,后来才发现自己想多了,只需要一个表格就可以实现了,如下 ?...数据库表的设置大概是这样,就是给这个表加上一个字段pId,这上面的关系怎么看,1和2的pId都是0就是说他们没有上一级,1-1和1-2的pId为1说明他们的上一级是1就是这样一层一层嵌套下去,这样就可以实现无限级的树形菜单...这个代码是怎么实现的,如下: 这个代码是怎么实现的,如下: 后台请求数据代码: public ActionResult ZtreeData(int id = 0) {...这是一个很简单的树形菜单,首先开始的在后台将数据库中的数据查询出来,前台就初始化这个树,通过url请求到数据,然后就在页面加载事件初始化这个树。

    3K10

    JS自定义右键菜单—复制到粘贴板(jQuery和原生JS实现)

    自定义右键菜单——复制到粘贴板 需求: 鼠标在li标签上点击右键出现菜单,主要是复制等功能 屏蔽浏览器默认右键点击事件 右键菜单出现在鼠标点击的位置 点击屏幕其他位置菜单消失 点击之后有回调 实现: 1...、使用jQuery - 右键菜单插件contextMenu 在项目中引入jquery.contextMenu.js 和 jquery.contextMenu.css, 同时 contextMenu...contextMenu插件:GitHub 主页 contextMenu插件:使用方法 2、使用原生js手撸一个 直接上代码: html: ...border-radius: 5px; list-style: none; margin: 5px; font-size: 16px; } JS...//阻止默认右键事件 return false; } document.onclick = function(e) { //click事件可以关闭右键菜单

    5K30
    领券