当前位置:首页 > 编程技术 > 正文内容

用HTML和CSS创建简洁而美观的树形菜单

yc8883个月前 (01-30)编程技术86

用HTML和CSS创建简洁而美观的树形菜单

在网页设计中,树形菜单是一种常见而有效的导航结构,特别适用于展示层级关系较为复杂的数据。本文将介绍如何使用HTML和CSS创建一个简洁而美观的树形菜单。

1. HTML 结构

首先,我们需要定义树形菜单的HTML结构。使用<ul>(无序列表)和<li>(列表项)标签来表示层级关系。

<div class="tree-menu">
    <ul>
        <li>
            <span class="caret">根节点</span>
            <ul class="nested">
                <li>子节点 1</li>
                <li>子节点 2</li>
                <li>
                    <span class="caret">子节点 3(含子节点)</span>
                    <ul class="nested">
                        <li>子节点 3.1</li>
                        <li>子节点 3.2</li>
                    </ul>
                </li>
            </ul>
        </li>
        <li>另一个根节点</li>
    </ul>
</div>

在这个简单的结构中,使用<span>标签表示可展开/折叠的节点,<ul><li>标签用于构建树形结构。

2. CSS 样式

添加一些简单的CSS样式,使树形菜单看起来更加美观。

.tree-menu {
    font-family: 'Arial', sans-serif;
}
ul {
    list-style-type: none;
    padding: 0;
}
li {
    margin: 0;
    padding: 8px;
    cursor: pointer;
}
.caret {
    user-select: none;
    margin-right: 5px;
}
.nested {
    display: none;
    padding-left: 20px;
}
.active {
    display: block;
}


这些样式主要用于去除默认样式、定义间距、设置鼠标指针形状,以及定义可展开/折叠的样式。

3. JavaScript 交互

为了使树形菜单能够展开和折叠,我们需要添加一些JavaScript代码。

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


这段JavaScript代码通过监听.caret元素的点击事件,切换相应节点的active类,实现菜单的展开和折叠。同时,通过切换caret-down类,实现可视化反馈。

4. 运行项目

将上述HTML、CSS和JavaScript代码保存到一个HTML文件中,然后在浏览器中打开。你将看到一个简洁而美观的树形菜单,用户可以方便地浏览和管理层级关系较为复杂的数据。

结语

通过简单的HTML结构、CSS样式和JavaScript交互,我们成功创建了一个树形菜单。这种树形结构对于展示层级关系的数据非常实用,而通过自定义样式和动态交互,我们可以让树形菜单更加直观和用户友好。希望这个简单教程能够帮助你在网页设计中使用树形菜单,为用户提供更好的导航体验。 Happy coding!


本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/10966.html

分享给朋友:

“用HTML和CSS创建简洁而美观的树形菜单” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】Java从resources读取文件内容的方法有哪些

【说站】Java从resources读取文件内容的方法有哪些

本文主要介绍的是java读取resource目录下文件的方法,比如这是你的src目录的结构├── main│ ├── java│ │ └── ...

【说站】使用systemctl配置dnspod-shell实现ddns

【说站】使用systemctl配置dnspod-shell实现ddns

这个是毛子路由器上用的脚本,由于碳云的nat服务器公网IP不断的变,因此只好通过ddns来稳定连接nat服务器了。顺便水一篇文章,大家新年快乐。使用前需要将域名添加到 DNSPod 中,并添加一条A记...

【说站】PHP使用Openssl实现本地生成csr、key、crt证书文件

【说站】PHP使用Openssl实现本地生成csr、key、crt证书文件

在Apache中要启用HTTPS访问,需要开启Openssl,也就需要crt和key两个和证书相关的文件了,那如果用制作呢?之前发过博文介绍过用在线生成的方式,但搞PHP编程的人有些东西还是想在自己的...