0

0

css 想快速实现手风琴折叠菜单怎么办_利用 css bootstrap collapse 组件

P粉602998670

P粉602998670

发布时间:2026-01-14 22:57:52

|

643人浏览过

|

来源于php中文网

原创

bootstrap collapse 必须引入 js 文件(如 bootstrap.bundle.min.js)才能生效,仅写 data-bs-toggle 和 data-bs-target 不起作用;html 结构需符合规范,目标容器要有 collapse 类和唯一 id;多折叠项互斥需用 accordion 容器并设置 data-bs-parent;动画异常多因 css 干扰 height/opacity 过渡;纯 css 方案(如 details/checkbox hack)兼容性差、可访问性弱,不推荐生产使用。

css 想快速实现手风琴折叠菜单怎么办_利用 css bootstrap collapse 组件

Bootstrap Collapse 怎么初始化才生效

直接写 data-bs-toggle="collapse"data-bs-target 不起作用,大概率是没引入 Bootstrap 的 JS 文件。Collapse 是 JS 驱动的交互组件,纯 CSS 无法触发展开/收起逻辑。

必须确保页面中已加载:

  • bootstrap.bundle.min.js(推荐,含 Popper)或 bootstrap.min.js + 单独 Popper
  • 对应版本的 bootstrap.min.css
  • HTML 结构符合官方要求:触发元素需有 data-bs-toggle="collapse",目标容器要有 collapse 类和唯一 id
<button class="btn btn-primary" type="button" data-bs-toggle="collapse" data-bs-target="#menu1">
  菜单项 1
</button>
<div class="collapse" id="menu1">
  <div class="card card-body">子菜单内容</div>
</div>

多个折叠项怎么互斥(手风琴效果)

默认 Collapse 是独立开关,要实现“打开一个、关闭其他”,不能只靠 HTML 属性,得用 JS 控制或改用 accordion 父容器。

最省事的方式:套一层 divaccordion 类,并给每个子项加 accordion-item,再用 data-bs-parent 指向该容器:

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

<div class="accordion" id="myAccordion">
  <div class="accordion-item">
    <h2 class="accordion-header">
      <button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#collapseOne" aria-expanded="false" aria-controls="collapseOne">
        标题 1
      </button>
    </h2>
    <div id="collapseOne" class="accordion-collapse collapse" data-bs-parent="#myAccordion">
      <div class="accordion-body">内容 1</div>
    </div>
  </div>
</div>

关键点:data-bs-parent 的值必须和父容器 id 完全一致,大小写敏感;accordion-button 类自带样式和状态管理,别漏掉。

秘塔回响
秘塔回响

秘塔AI语音输入法

下载

折叠动画卡顿或不出现?检查这些 CSS 干扰

Collapse 依赖 heightoverflow 的 CSS 过渡,以下情况会导致动画失效或突兀:

  • 目标元素设置了 display: nonevisibility: hidden —— Collapse 内部靠 JS 切换 heightopacity,手动加这些会冲突
  • 父容器有 overflow: hidden 但高度固定 —— 动画过程中内容被裁剪,看起来像“闪一下”
  • 自定义了 .collapsetransition,但没包含 heightopacity —— 默认过渡属性是 height .35s ease, visibility .35s ease, opacity .35s ease

稳妥做法:不覆盖 .collapse 基础样式,如需微调动画时,只重写 transition 并保留全部三项。

不用 Bootstrap JS,纯 CSS 能做手风琴吗

能,但限制明显:必须用 <details><summary></summary></details>,这是原生 HTML 元素,无需 JS,但兼容性差(IE 完全不支持,iOS Safari 旧版有 bug),且样式定制困难。

如果坚持纯 CSS + 更好兼容性,可用 checkbox hack(利用 :checked + ~ 选择器),但存在严重缺陷:

  • 无法用键盘操作(Enter/Space 触发)
  • SEO 不友好(内容在 DOM 中但初始不可见,且无语义化结构)
  • 移动端点击区域难控制,容易误触
  • 无法监听展开/收起事件,后续扩展逻辑(如懒加载)几乎不可行

结论:真要快速上线、兼顾可访问性和维护性,Bootstrap Collapse 是当前最省心的选择;所谓“纯 CSS 方案”,实际是拿可维护性和健壮性换来的临时妥协。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

759

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6147

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.09.04

Js中concat和push的区别
Js中concat和push的区别

Js中concat和push的区别:1、concat用于将两个或多个数组合并成一个新数组,并返回这个新数组,而push用于向数组的末尾添加一个或多个元素,并返回修改后的数组的新长度;2、concat不会修改原始数组,是创建新的数组,而push会修改原数组,将新元素添加到原数组的末尾等等。本专题为大家提供concat和push相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.09.14

js截取字符串的方法介绍
js截取字符串的方法介绍

JavaScript字符串截取方法,包括substring、slice、substr、charAt和split方法。这些方法可以根据具体需求,灵活地截取字符串的不同部分。在实际开发中,根据具体情况选择合适的方法进行字符串截取,能够提高代码的效率和可读性 。

300

2023.09.21

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

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

4

2026.03.10

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 41.6万人学习

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

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