0

0

使用JavaScript和Bootstrap实现可切换侧边栏的按钮

霞舞

霞舞

发布时间:2025-10-28 10:41:22

|

733人浏览过

|

来源于php中文网

原创

使用JavaScript和Bootstrap实现可切换侧边栏的按钮

本教程详细介绍了如何利用htmlbootstrap框架以及纯javascript创建一个可切换显示/隐藏的侧边栏按钮。通过识别关键dom元素并编写简洁的事件监听器,您可以轻松实现一个交互式侧边导航菜单,提升用户界面的灵活性和用户体验。

侧边栏是现代网页设计中常见的导航元素,它能有效地组织内容并节省屏幕空间。为了提供更好的用户体验,通常需要一个按钮来控制侧边栏的显示与隐藏。本文将指导您如何使用HTML、Bootstrap和JavaScript实现这一功能。

HTML 结构准备

首先,我们需要准备侧边栏和切换按钮的HTML结构。确保侧边栏和按钮都具有唯一的id属性,以便JavaScript能够准确地选中它们。在本例中,侧边栏的id为sidebar,切换按钮的id为menu-toggle。我们使用Bootstrap的布局类来构建基本的页面结构。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>可切换侧边栏示例</title>
  <!-- 引入Bootstrap CSS -->
  <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
  <!-- 引入Font Awesome图标库 -->
  <script src="https://kit.fontawesome.com/60bf89e922.js" crossorigin="anonymous"></script>
  <style>
    /* 可选:为侧边栏添加过渡效果,使其切换更平滑 */
    .sidebar {
      transition: all 0.3s ease-in-out;
    }
    /* 如果希望侧边栏初始状态为隐藏,可以在此处设置 */
    /* #sidebar { display: none; } */
  </style>
</head>
<body>

  <header class="header row">
    <div class="d-flex justify-content-between">
      <div id="logo" class="pb-2 ps-2 pe-0 col-2">
        <img class="float-start py-2 ps-2 pe-2" src="assets/img/unknown.png" alt="Logo">
        <!-- 侧边栏切换按钮,通过id 'menu-toggle' 识别 -->
        <a href="#" class="sidebar-toggler flex-shrink-0" id="menu-toggle">
          <i class="fa-solid fa-angle-left py-4 pe-2"></i>
        </a>
      </div>
    </div>
  </header>

  <div class="body row">
    <!-- 侧边栏容器,通过id 'sidebar' 识别 -->
    <div class="sidebar col-2" id="sidebar">
      <div class="navbar-nav w-100">
        <div class="nav-item dropdown">
          <a href="#" class="nav-link dropdown-toggle" data-bs-toggle="dropdown"><i class="fa fa-laptop me-2"></i>Admin</a>
          <div class="dropdown-menu bg-transparent border-0">
            <a href="#" class="dropdown-item">A</a>
            <a href="#" class="dropdown-item">B</a>
            <a href="#" class="dropdown-item">C</a>
          </div>
        </div>
        <a href="#" class="nav-item nav-link"><i class="fa fa-th me-2"></i>Cập nhật PO</a>
        <a href="#" class="nav-item nav-link"><i class="fa fa-keyboard me-2"></i>Phân loại PO</a>
        <a href="#" class="nav-item nav-link"><i class="fa fa-chart-bar me-2"></i>Ước tính rebate</a>
        <a href="#" class="nav-item nav-link"><i class="fa fa-tachometer-alt me-2"></i>Cập nhật rebate</a>
        <a href="#" class="nav-item nav-link"><i class="fa fa-tachometer-alt me-2"></i>Báo cáo</a>
        <a href="#" class="nav-item nav-link"><i class="fa fa-tachometer-alt me-2"></i>Tra cứu thông tin</a>
        <a href="#" class="nav-item nav-link"><i class="fa fa-tachometer-alt me-2"></i>Hướng dẫn sử dụng</a>
      </div>
    </div>
    <!-- 主内容区域 -->
    <div class="content col-10"> Content </div>
  </div>

  <!-- JavaScript代码应放在body结束标签之前 -->
  <script>
    // 确保DOM内容完全加载后再执行脚本
    document.addEventListener('DOMContentLoaded', function() {
      const menuToggle = document.querySelector('#menu-toggle');
      const sidebar = document.querySelector('#sidebar');

      // 为切换按钮添加点击事件监听器
      menuToggle.onclick = function(e) {
        e.preventDefault(); // 阻止a标签默认的跳转行为

        // 检查侧边栏当前的display样式
        if (sidebar.style.display !== 'none') {
          sidebar.style.display = 'none'; // 如果不是隐藏状态,则将其隐藏
        } else {
          sidebar.style.display = 'block'; // 如果是隐藏状态,则将其显示
        }
      };
    });
  </script>

</body>
</html>

JavaScript 切换逻辑

核心功能通过一段简洁的JavaScript代码实现。这段代码监听切换按钮的点击事件,并根据侧边栏当前的显示状态来切换其display样式属性。

  1. 获取元素引用: 使用document.querySelector()方法获取侧边栏元素(通过#sidebar)和切换按钮元素(通过#menu-toggle)。
  2. 添加事件监听器: 为切换按钮的onclick事件绑定一个处理函数。为了确保脚本在DOM加载完成后执行,我们将其包裹在DOMContentLoaded事件监听器中。
  3. 切换显示状态: 在事件处理函数内部,通过检查sidebar.style.display的值来判断侧边栏当前是显示还是隐藏。
    • 如果display不为'none'(即侧边栏可见),则将其设置为'none'以隐藏。
    • 否则(即侧边栏已隐藏),则将其设置为'block'以显示。
  4. 阻止默认行为: 由于切换按钮是一个<a>标签,其默认行为是跳转。e.preventDefault()用于阻止这一默认行为,确保点击按钮只执行侧边栏切换逻辑。

注意事项与优化

  • CSS Class 切换(推荐): 直接操作style.display虽然简单,但在更复杂的场景(如需要动画效果或维护多种状态)下可能不够灵活。更推荐的做法是通过JavaScript添加或移除CSS类。例如,可以定义一个.sidebar-hidden { display: none; }类,然后使用sidebar.classList.toggle('sidebar-hidden')来切换。这样可以将样式与行为分离,提高代码的可维护性和可扩展性。

    立即学习Java免费学习笔记(深入)”;

    阿里妈妈·创意中心
    阿里妈妈·创意中心

    阿里妈妈营销创意中心

    下载
  • 初始状态设置: 如果希望侧边栏在页面加载时默认是隐藏的,可以在CSS中为#sidebar元素添加display: none;样式。

  • 响应式设计: 结合Bootstrap的响应式工具类(如d-none d-lg-block),可以根据屏幕尺寸动态调整侧边栏的可见性,提供更佳的移动端体验。例如,在小屏幕上默认隐藏侧边栏,在大屏幕上默认显示。

  • 可访问性 (Accessibility): 为了提高网页的可访问性,建议为切换按钮添加aria-expanded和aria-controls等ARIA属性,并在JavaScript中根据侧边栏的显示状态动态更新这些属性。例如:

    // ...
    menuToggle.setAttribute('aria-controls', 'sidebar');
    let isSidebarExpanded = true; // 假设初始是展开的
    menuToggle.setAttribute('aria-expanded', String(isSidebarExpanded));
    
    menuToggle.onclick = function(e) {
      e.preventDefault();
      isSidebarExpanded = !isSidebarExpanded;
      sidebar.style.display = isSidebarExpanded ? 'block' : 'none';
      menuToggle.setAttribute('aria-expanded', String(isSidebarExpanded));
    };
    // ...

总结

通过上述步骤,您已经成功创建了一个使用JavaScript和Bootstrap控制侧边栏显示/隐藏的按钮。这种方法简单直接,适用于快速实现交互功能。在实际项目中,可以根据需求进一步优化,例如引入CSS过渡动画、使用CSS类进行状态管理或更完善的可访问性支持,以构建更健壮和用户友好的界面。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

911

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4377

2024.08.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

48

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

88

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

270

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

59

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

99

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

105

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号