details 默认收起,需加 open 属性才能默认展开;summary 内嵌图标易致点击失效,推荐伪元素添加;JS 应操作 open 属性而非 class,并监听 toggle 事件;原生下箭头样式受限,自定义需权衡语义与控制力。
直接写 默认是收起状态。想一开页面就展开,必须加 标题
内容open 属性:。漏掉这个属性,用户就得手动点一下才能看到内容——这不是 bug,是规范行为。
是唯一可触发展开/收起的交互区域,里面如果嵌了 、 或其他非文本元素,某些浏览器(尤其是旧版 Safari)可能无法响应点击。稳妥做法是:
::before 或 ::after 伪元素添加图标,不破坏 的原生语义和事件绑定 设置 display: flex 或 display: inline-flex,并给图标加 pointer-events: none
class 的开关逻辑由原生 open 属性控制,不是靠 class 切换。用 JS 操作时:
el.setAttribute('open', '') 或 el.open = true
el.removeAttribute('open') 或 el.open = false
toggle 事件,不是 click —— 因为键盘空格/回车也能触发const details = document.querySelector('details');
details.addEventListener('toggle', () => {
console.log('当前状态:', details.open);
});
浏览器对 的默认下拉箭头(如 Chrome 的三角)不提供标准 CSS 接口隐藏或替换。常见绕过方式:
list-style: none + appearance: none 清除部分浏览器默认样式summary::marker 隐藏(仅 Firefox 支持;Chrome/Safari 尚未实现) 替代 ,再用 JS 控制 details.open —— 牺牲一点语义,换来 100% 可控真正难的不是怎么写出来,而是判断什么时候该坚持语义用原生 details,什么时候该退一步手写 toggle 逻辑。前者利于无障碍和 SEO,后者胜在样式和交互自由度。别硬套。