0

0

HTML的details和summary标签怎么实现折叠内容?

煙雲

煙雲

发布时间:2025-07-13 15:28:02

|

698人浏览过

|

来源于php中文网

原创

要自定义details标签的默认状态和样式,首先可通过在details标签添加open属性使其默认展开;其次,通过css控制summary伪元素来自定义指示器样式。具体步骤如下:1. 使用open属性实现默认展开状态;2. 通过summary::-webkit-details-marker隐藏原生标记;3. 利用summary::before伪元素添加自定义图标;4. 通过details[open] summary::before设置展开时的图标变化;5. 结合过渡效果提升视觉体验。此外,还可结合javascript实现更复杂的交互,如手风琴效果、动态加载内容等,进一步增强功能表现。

HTML的details和summary标签怎么实现折叠内容?

HTML的details和summary标签提供了一种非常直接、原生的方式来实现内容折叠与展开,不需要你写一行JavaScript。简单来说,details就是那个可以被折叠的容器,而summary则是你点击来控制折叠的标题或者说触发器。点击summary,details里面的内容就会神奇地出现或消失。

解决方案

实现起来异常简单,代码结构一目了然:

<details>
  <summary>点击这里查看更多内容</summary>
  <p>这是折叠起来的内容,只有当你点击了上面的标题,它才会显示出来。是不是很方便?</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
  <ul>
    <li>列表项1</li>
    <li>列表项2</li>
  </ul>
</details>

<details open>
  <summary>这个是默认展开的哦</summary>
  <p>通过在details标签上添加一个`open`属性,就能让它加载时就处于展开状态。</p>
</details>

如何自定义details标签的默认状态和样式?

说实话,我第一次用这玩意儿的时候,就想把那个小箭头换掉,或者让它默认就是展开的。这很简单。

默认展开状态,只需要在<details></details>标签上加个open属性就行了,就像上面示例里那样。

至于那个小小的、通常是三角形的展开/收起指示器,也就是所谓的“标记”,我们可以用CSS来控制它。这个标记实际上是summary元素的一个伪元素。

你可以直接隐藏它:

OneAI
OneAI

将生成式AI技术打包为API,整合到企业产品和服务中

下载
summary {
  list-style: none; /* 针对Firefox和一些旧版浏览器 */
}
summary::-webkit-details-marker { /* 针对WebKit内核浏览器,如Chrome、Safari */
  display: none;
}
/* 如果你想用自己的图标来替代,可以这样 */
summary {
  list-style: none;
  position: relative;
  padding-left: 20px; /* 给图标留出空间 */
  cursor: pointer;
}
details[open] summary {
  /* 展开时的样式,比如标题加粗 */
  font-weight: bold;
}
summary::before {
  content: '+'; /* 默认显示加号 */
  position: absolute;
  left: 0;
  top: 0;
  font-weight: bold;
  transition: transform 0.2s ease-in-out; /* 添加过渡效果 */
}
details[open] summary::before {
  content: '-'; /* 展开时显示减号 */
  transform: rotate(0deg); /* 如果是箭头,可以旋转 */
}

通过这种方式,你完全可以替换成任何你想要的图标,比如SVG或者字体图标,给用户更直观的视觉反馈。

details标签在实际应用中有哪些常见场景和优势?

这东西用起来是真的香,尤其在一些特定场景下。我个人觉得它最大的优势就是原生、语义化和可访问性。

最常见的应用场景,那肯定是FAQ(常见问题解答)。每个问题都是一个summary,答案藏在details里,页面一下就整洁了。还有像产品详情页,那些不那么核心但用户可能想看的信息,比如“退换货政策”、“详细参数”,都可以用它来收纳。教程或者文档里,一些可选的、进阶的步骤或者解释,也可以用它来做“渐进式披露”,让用户按需查看,避免信息过载。

它的语义化,意味着搜索引擎和辅助技术(比如屏幕阅读器)能更好地理解这块内容的结构和作用。而且,它天生支持键盘导航,用户不需要鼠标也能通过Tab键聚焦到summary,然后按回车或空格键来展开/收起,这对于可访问性来说是个巨大的加分项。相比那些纯JavaScript实现的折叠效果,details标签在性能上也更占优,毕竟是浏览器原生支持的,开销极小。

如何结合CSS和JavaScript进一步增强details标签的功能?

虽然details标签本身已经很强大了,但有时候我们可能需要更精细的控制,或者实现一些原生不支持的复杂交互,比如“手风琴”效果——即点击一个展开,其他已展开的自动收起。这时候,JavaScript就派上用场了。

要实现手风琴效果,你可以监听details元素的toggle事件。这个事件会在details状态改变(从展开到收起,或从收起到展开)时触发。

一个简单的手风琴实现思路是:

document.querySelectorAll('details').forEach(details => {
  details.addEventListener('toggle', () => {
    if (details.open) { // 如果当前这个details被打开了
      document.querySelectorAll('details').forEach(otherDetails => {
        if (otherDetails !== details && otherDetails.open) {
          otherDetails.open = false; // 关闭其他所有已打开的details
        }
      });
    }
  });
});

这段代码会遍历页面上所有的details标签,给它们都加上一个toggle事件监听。当某个details被打开时,它会检查其他的details,如果发现有其他details也是打开的,就把它关掉。这样就实现了“一次只能打开一个”的效果。

除了这种交互逻辑,JavaScript还能用来做很多事,比如:

  • 跟踪用户行为:记录用户点击了哪些summary,哪些内容被展开了,这对于数据分析很有用。
  • 动态加载内容:如果折叠的内容很多或者需要从后端获取,你可以在toggle事件触发时,当details被打开时,才去异步加载里面的内容,提高页面初始加载速度。
  • 复杂的动画效果:虽然CSS也能做一些动画,但更复杂的、基于状态变化的动画,用JS控制会更灵活。

总的来说,details和summary标签提供了一个坚实的原生基础,而CSS和JavaScript则是你用来打磨和扩展其功能的利器。用好它们,能让你的网页交互既原生高效,又富有表现力。

热门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字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

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方法。这些方法可以根据具体需求,灵活地截取字符串的不同部分。在实际开发中,根据具体情况选择合适的方法进行字符串截取,能够提高代码的效率和可读性 。

302

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.7万人学习

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

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