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

js+树形菜单效果

要在JavaScript中实现树形菜单效果,你可以使用HTML、CSS和JavaScript来构建一个交互式的树形结构。以下是一个简单的实现示例:

HTML结构

代码语言:txt
复制
<ul id="treeMenu">
    <li>
        <span class="toggle">+</span> <span class="menu-label">菜单1</span>
        <ul class="sub-menu">
            <li><span class="menu-label">子菜单1-1</span></li>
            <li><span class="menu-label">子菜单1-2</span></li>
        </ul>
    </li>
    <li>
        <span class="toggle">+</span> <span class="menu-label">菜单2</span>
        <ul class="sub-menu">
            <li><span class="menu-label">子菜单2-1</span></li>
            <li>
                <span class="toggle">+</span> <span class="menu-label">子菜单2-2</span>
                <ul class="sub-menu">
                    <li><span class="menu-label">子菜单2-2-1</span></li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

CSS样式

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

.sub-menu {
    display: none;
    list-style-type: none;
    padding-left: 20px;
}

.toggle {
    cursor: pointer;
    margin-right: 5px;
}

JavaScript交互

代码语言:txt
复制
document.addEventListener('DOMContentLoaded', function() {
    var toggles = document.querySelectorAll('.toggle');

    toggles.forEach(function(toggle) {
        toggle.addEventListener('click', function() {
            var subMenu = this.nextElementSibling.nextElementSibling;
            if (subMenu.style.display === 'none' || subMenu.style.display === '') {
                subMenu.style.display = 'block';
                this.textContent = '-';
            } else {
                subMenu.style.display = 'none';
                this.textContent = '+';
            }
        });
    });
});

解释

  1. HTML: 创建了一个嵌套的无序列表来表示树形菜单结构。每个可展开的菜单项前都有一个span元素作为切换按钮。
  2. CSS: 设置了基本的样式,其中.sub-menu默认是隐藏的,.toggle用于显示切换按钮。
  3. JavaScript: 当文档加载完成后,为每个切换按钮添加点击事件监听器。点击时,切换相应子菜单的显示状态,并改变切换按钮的符号。

优势

  • 交互性: 用户可以展开和折叠菜单,提高用户体验。
  • 可扩展性: 可以轻松添加更多的菜单项和子菜单。
  • 简洁性: 使用简单的HTML、CSS和JavaScript即可实现。

应用场景

  • 网站导航: 适用于需要多层次导航的网站。
  • 后台管理系统: 管理员可以通过树形菜单快速访问不同的管理功能。
  • 文件浏览器: 显示文件和文件夹的层次结构。

这个基础示例可以根据具体需求进行扩展,例如添加动画效果、键盘导航支持、动态加载菜单项等。

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

相关·内容

  • zTree实现树形结构菜单

    文章目录 一、简介 二、前端渲染效果 三、实现步骤 1、数据库表结构 2、引入zTree插件 3、树形结构实体类SysModule 4、表示层代码 5、js渲染部分 1、树初始化配置 2、加载数据树...二、前端渲染效果 三、实现步骤 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、树形结构实体类...private String parentCode; /**是否为叶子节点*/ private int isLeaf; /**同级排序编号*/ private int sortNumber; } 树形结构辅助类...userCode=#{userCode})") List getmoduleCodes(@Param("userCode") String userCode); // 获取树形结构所有父节点

    5.5K40

    动态加载的树形菜单

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

    3K10

    JAVA中怎样实现树形菜单

    就是在实际开发过程中,总会遇到菜单,或则是权限,这个时候就涉及到后端返回数据给前端的时候,不能一个集合把数据一股脑的全部扔给前端,总要把数据整理好,做成像书目录一样的结构返回给前端。...', parent_id int(11) NOT NULL DEFAULT '0' COMMENT '父目录ID', menu_name varchar(255) NOT NULL COMMENT '菜单名称...', menu_level int(11) NOT NULL COMMENT '菜单等级', route varchar(255) NOT NULL COMMENT '路由', PRIMARY KEY...id) COMMENT '主键', UNIQUE KEY parent_id (parent_id,menu_name,menu_level,route) COMMENT '唯一索引,包含父目录ID、菜单名称...、菜单等级和路由' ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT '存储引擎为InnoDB,字符集为utf8'; ②向表中插入数据 SQL复制代码INSERT

    15010

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

    一、树形菜单设计思考 树形是一种非常自然而常见结构,它可以展示大量具有自相似的信息。...子区域的偏移也能更好的展示树形的层次结构。 本文将探讨 TolyUI 在树形导航菜单中的设计。 1. 树形菜单设计动机 树形菜单是 Flutter 本身不支持的,但在桌面端或 Web 端中是非常常见。...树形菜单的职能 树形菜单在交互语义上承担的职能是: [1]. 承载若干个 视图元件 ,并参与交互。 [2]. 视图元件 间呈树形组织结构。 [3]. 允许交互时,动画折叠/收起子节点。...下面是 PLCKI 项目导航的树形结构效果,采用了 TolyUI 的默认风格: 3. 树形菜单在使用上的设计 树形结构在使用时,最复杂的地方莫过于节点对象的创建。...树形菜单配置参数 树形菜单和侧栏菜单类似,可以配置上方和下方区域的组件,以及右侧边线区域,可拉伸面板。

    32910

    Laravel入门之实现菜单的树形分类

    实现菜单的树形分类主要是有两个比较重要的点,上图我们可以看到分类是三级分类,实现了对菜单的限制,其中主要是有以下几个点需要注意,之后就乘上热乎乎的代码: SQL语句的拼接撰写,形成原始数据; 前台渲染根据...path路径字符串判断需要加几处分段符; 判断三层菜单,并禁止三层菜单继续向下分级。...路由设置 Route::get('types', 'TypesController@index'); 后端读取处理方法 /** * 菜单控制首页 * @return \Illuminate\Contracts...*/ public function index(){ // 求取行数 $count = DB::table('dzushop_types')->count(); // 查询树形结构并且运用...span class="btn btn-sm btn-rounded btn-gradient-primary">添加子类 @endif 最终效果图

    2.4K20
    领券