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

js树形菜单设计代码

好的,下面是一个简单的JavaScript树形菜单设计的示例代码。这个示例使用了HTML、CSS和JavaScript来实现一个可展开和折叠的树形菜单。

HTML部分

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Tree Menu</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div class="tree-menu">
        <ul>
            <li>
                <span class="caret">Node 1</span>
                <ul class="nested">
                    <li>Subnode 1.1</li>
                    <li>Subnode 1.2</li>
                </ul>
            </li>
            <li>
                <span class="caret">Node 2</span>
                <ul class="nested">
                    <li>Subnode 2.1</li>
                    <li>Subnode 2.2</li>
                </ul>
            </li>
            <li>Node 3</li>
        </ul>
    </div>
    <script src="script.js"></script>
</body>
</html>

CSS部分(styles.css)

代码语言:txt
复制
.tree-menu ul {
    list-style-type: none;
    padding-left: 20px;
}

.caret {
    cursor: pointer;
    user-select: none;
}

.caret::before {
    content: "\25B6";
    color: black;
    display: inline-block;
    margin-right: 6px;
}

.caret-down::before {
    transform: rotate(90deg);
}

.nested {
    display: none;
}

.active {
    display: block;
}

JavaScript部分(script.js)

代码语言:txt
复制
document.addEventListener('DOMContentLoaded', function() {
    const toggler = document.getElementsByClassName('caret');
    let i;

    for (i = 0; i < toggler.length; i++) {
        toggler[i].addEventListener('click', function() {
            this.parentElement.querySelector('.nested').classList.toggle('active');
            this.classList.toggle('caret-down');
        });
    }
});

解释

  1. HTML部分:定义了树形菜单的结构,每个节点包含一个<span>元素作为展开/折叠的触发器。
  2. CSS部分:设置了树形菜单的样式,包括隐藏子节点和显示展开/折叠的箭头。
  3. JavaScript部分:添加了事件监听器,当点击某个节点时,切换其子节点的显示状态,并更新箭头的样式。

应用场景

  • 网站导航:用于网站的侧边栏或顶部导航栏。
  • 文件浏览器:模拟文件系统的目录结构。
  • 设置面板:展示多层次的配置选项。

优势

  • 直观的用户体验:用户可以通过简单的点击来展开和折叠菜单项。
  • 灵活性:可以轻松地添加、删除或修改菜单项。
  • 响应式设计:适用于各种屏幕尺寸和设备。

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

  1. 子节点不显示:确保CSS中的.nested类初始状态为display: none;,并且在JavaScript中正确切换.active类。
  2. 箭头图标不正确:检查CSS中的伪元素选择器和变换是否正确应用。
  3. 事件监听器未绑定:确保JavaScript代码在DOM完全加载后执行,可以使用DOMContentLoaded事件。

希望这个示例能帮助你理解如何设计和实现一个简单的树形菜单。如果有任何具体问题或需要进一步的帮助,请随时提问!

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

相关·内容

Flutter TolyUI 框架#05 | 树形菜单设计

一、树形菜单设计思考 树形是一种非常自然而常见结构,它可以展示大量具有自相似的信息。...子区域的偏移也能更好的展示树形的层次结构。 本文将探讨 TolyUI 在树形导航菜单中的设计。 1. 树形菜单设计动机 树形菜单是 Flutter 本身不支持的,但在桌面端或 Web 端中是非常常见。...其中条目提供了 TolyUI 的默认样式,并且也提供了菜单项的自定义构建途径。 TolyUI 模块化设计中,树形菜单对应的组件是 TolyRailMenuTree。...下面是 PLCKI 项目导航的树形结构效果,采用了 TolyUI 的默认风格: 3. 树形菜单在使用上的设计 树形结构在使用时,最复杂的地方莫过于节点对象的创建。...菜单节点树的解析 如果仅靠手动书写菜单节点树,会写出非常复杂的代码。比如下面的伪代码,这不仅不便于阅读和维护,也不便于数据传输。

32910
  • zTree实现树形结构菜单

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

    5.5K40

    动态加载的树形菜单

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

    3K10

    JAVA中怎样实现树形菜单

    在这里我会很详细的讲解每一步代码,主要是方便新人看懂,弥补曾经自己学习过程中的苦恼。提醒:如果第一种写法理解不了或则看不懂,可以看第二种写法,通过第二种写法去理解第一种的写法,两种写法逻辑是一样的。...就是在实际开发过程中,总会遇到菜单,或则是权限,这个时候就涉及到后端返回数据给前端的时候,不能一个集合把数据一股脑的全部扔给前端,总要把数据整理好,做成像书目录一样的结构返回给前端。...就像以下图示一样 二、目录树结构实现写法 1、准备阶段 ①创建数据表 PS:如果是练习可以不用创建数据库,数据全部通过java代码来创建也可以 sql复制代码CREATE TABLE permission_directory...、菜单等级和路由' ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT '存储引擎为InnoDB,字符集为utf8'; ②向表中插入数据 SQL复制代码INSERT...("路由") private String route; } ④创建存储菜单对象PermissionDirectoryResVO类 Java复制代码@Data public class PermissionDirectoryResVO

    15010

    设计高性能树形菜单,支持数十万条数据加载。

    在软件中增加[自定义树形菜单]一直悬而未决,直到最近更新了增加树形菜单功能。...【更新】240523 属性扩展支持自定义树形菜单,大容量树形结构,制作层级网格 传统树形菜单使用dom处理,如果根结点数据有1万个,至少为产生1万个dom,这对应用来说是无法接受的。有人说分页处理?...如何解决大数据量的树形数据展示、选择? 下图是在***Geobuilding***软件中绘制的几个polygon要素。发现了什么?这看起来像极了树形菜单! 我们知道Geojson数据有点/线/面。...这样树形菜单的样式和点击事件不是都有了吗?...生成树形菜单Geojson数据 树形数据格式一般如下 css复制代码[{"text":"北京市","id":"11"},{"text":"市辖区","id":"1101","pid":"11"},{"text

    14400

    非递归实现树形下拉菜单

    非递归实现树形下拉菜单 博主 默语带您 Go to New World....我还是 Java 高级工程师、自媒体博主,北京城市开发者社区的主理人,拥有丰富的项目开发经验和产品设计能力。...好的,我会更详细地讲解 非递归实现树形下拉菜单 的完整思路和代码,同时为每一部分都加上清晰的注释,让初学者也能看懂。这次我们会以逐步实现的方式讲解每一步的逻辑。...非递归实现树形下拉菜单 什么是非递归实现? 在递归中,函数会自己调用自己。非递归实现是用 队列(Queue) 或 栈(Stack) 来替代函数调用栈,从而手动管理需要处理的数据,逐步完成任务。...完整代码(队列实现) import java.util.*; public class CategoryTreeBuilder { /** * 构建树形结构(非递归方式,使用队列实现

    9210

    MySQL树形结构(多级菜单)的数据库表设计和查询

    概述 想必下面的树形菜单大家都见过,但是是如何实现的,你们有没有想过?...说下我是怎么想起设计这个东西的,在一个惠风和畅,风和日丽的午后,我盯着眼前已完成的项目陷入沉思,良久,我将树形菜单的每一级菜单都设计成为了单独的表,正准备写接口将所有的菜单都返回的时候,带我的哥哥给我讲了一遍树形菜单的结构与数据库如何设计...数据库的设计 其实简单来讲就是为每个菜单栏在添加一个parent_id字段,记录着自己父菜单的ID,以下面的菜单为例,我给出了对应数据库简单的设计,想必你一看就明白了。...树形菜单的查询 数据库的设计虽然已经完成了,但是我们如何实现查询呢?...ApiModelProperty("该菜单的名称") private String name; @ApiModelProperty("该菜单的父菜单的ID") private Integer

    10.7K10
    领券