js+css侧边导航菜单 可收缩

js+css侧边导航菜单 可收缩https://www.bootstrapmb.com/item/14774

创建一个可收缩的侧边导航菜单需要使用JavaScript来处理交互,而CSS则用来设置样式和动画效果。以下是一个简单的示例,展示了如何创建一个可收缩的侧边导航菜单。

HTML 结构

复制代码
复制代码
html`<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>可收缩侧边导航菜单</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>

<div id="sidebar" class="sidebar">
<ul>
<li><a href="#">链接 1</a></li>
<li><a href="#">链接 2</a></li>
<li><a href="#">链接 3</a></li>
<!-- ...更多链接 -->
</ul>
<span id="toggle-btn" class="toggle-btn">☰</span>
</div>

<div id="content" class="content">
<!-- 页面内容 -->
<p>点击左上角的菜单图标来显示/隐藏侧边栏。</p>
</div>

<script src="script.js"></script>
</body>
</html>`

CSS 样式 (styles.css)

复制代码
复制代码
css`body {
margin: 0;
padding: 0;
overflow-x: hidden; /* 防止内容在侧边栏展开时水平滚动 */
}

.sidebar {
width: 200px; /* 侧边栏宽度 */
height: 100vh; /* 视口高度 */
background: #333;
color: #fff;
position: fixed;
top: 0;
left: -200px; /* 初始位置在屏幕左侧外部 */
transition: left 0.3s ease-in-out; /* 平滑过渡效果 */
z-index: 1000; /* 确保侧边栏在内容之上 */
}

.sidebar ul {
list-style: none;
padding: 0;
margin: 0;
}

.sidebar li a {
display: block;
padding: 15px;
text-decoration: none;
color: inherit;
}

.sidebar li a:hover {
background: #444;
}

.toggle-btn {
position: absolute;
top: 10px;
left: 10px;
font-size: 24px;
color: #fff;
cursor: pointer;
}

.content {
padding: 20px;
margin-left: 200px; /* 与侧边栏宽度相同,确保内容不会重叠 */
transition: margin-left 0.3s ease-in-out; /* 平滑过渡效果 */
}

.sidebar.active {
left: 0; /* 侧边栏展开时移动到屏幕左侧 */
}

.content.active {
margin-left: 200px; /* 侧边栏展开时内容区域的左边距增加 */
}`

JavaScript 交互 (script.js)

复制代码
复制代码
javascript`document.getElementById('toggle-btn').addEventListener('click', function() {
const sidebar = document.getElementById('sidebar');
const content = document.getElementById('content');

sidebar.classList.toggle('active');
content.classList.toggle('active');
});`

以上示例创建了一个简单的可收缩侧边导航菜单。侧边栏初始时位于屏幕左侧外部,并可通过点击左上角的菜单图标来展开和隐藏。页面内容也会根据侧边栏的展开或隐藏状态相应地调整其左边距。

相关推荐
加班是不可能的,除非双倍日工资1 小时前
css预编译器实现星空背景图
前端·css·vue3
lifallen1 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研1 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
gnip2 小时前
vite和webpack打包结构控制
前端·javascript
cui__OaO3 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习
鱼鱼说测试3 小时前
Jenkins+Python自动化持续集成详细教程
开发语言·servlet·php
艾莉丝努力练剑3 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
CHEN5_024 小时前
【Java基础面试题】Java基础概念
java·开发语言
烛阴4 小时前
前端必会:如何创建一个可随时取消的定时器
前端·javascript·typescript
萌萌哒草头将军4 小时前
Oxc 最新 Transformer Alpha 功能速览! 🚀🚀🚀
前端·javascript·vue.js