因为counter-reset定义计数器作用域,若设在.list-group-item上会导致每个项重置为1;必须设在.list-group容器上,由其统一管理后代递增,确保序号连续。
counter-reset 要放在 .list-group 上而不是 .list-group-item
因为 CSS 计数器作用域由 counter-reset 所在元素定义——它重置的是该元素的**后代上下文**。如果把 counter-reset: item; 写在 .list-group-item 上,每个 item 都会各自重置为 1,结果全是 “1.”。必须让整个列表容器(即 .list-group)统一管理计数器,才能递增。
实操建议:
立即学习“前端免费学习笔记(深入)”;
.list-group { counter-reset: item; } 是必要前提.list-group 默认是 display: block,兼容计数器;若自定义改过 display(比如设成 flex),需确认仍支持伪元素生成内容.list-group 上同时用 counter-increment——它应只出现在要显示序号的子元素上直接在 .list-group-item::before 插入序号会导致文字整体右移,和原生样式错位。关键是利用绝对定位 + 左侧留白,复用 Bootstrap 的 padding-left 逻辑。
实操建议:
立即学习“前端免费学习笔记(深入)”;
.list-group-item 设置 position: relative;
.list-group-item::before 绝对定位到左侧,宽度固定(如 width: 2em;),并设置 text-align: right;
padding-left: 2.5em; 把内容往右推,腾出序号空间——这个值要略大于 ::before 宽度,防止重叠"." 用 content: counter(item) ".";,比拼字符串更可靠当 .list-group-item 内部包含 a、button 或其他交互元素,且你试图对这些子元素用 ::before,序号就会乱:要么重复出现,要么被覆盖。根本原因是计数器递增必须绑定到**实际渲染的块级容器**上。
实操建议:
立即学习“前端免费学习笔记(深入)”;
.list-group-item(而非其子元素)应用 counter-increment: item;
<a>,不要给 a::before 加序号——它继承父级计数器值,但不会触发递增.list-group-item:hover::before 控制颜色,别碰 counter-increment
.list-group)需单独命名计数器,例如 counter-reset: subitem;,避免和外层冲突CSS Counters 在 IE8+ 基本可用,但 IE11 对 counter() 函数在 flex 容器中的行为不稳定;某些安卓 WebView(尤其 4.x)会忽略 ::before 中的 counter()。这不是 Bootstrap 问题,而是底层渲染引擎限制。
实操建议:
立即学习“前端免费学习笔记(深入)”;
@supports not (counter-reset: a) { ... } 检测并 fallback 到纯背景图或内联 SVG 序号(需预设最大项数)counter() 中使用 counter(item, lower-alpha) 等格式化——IE11 只认默认十进制list-style-type: decimal; 配合 ol.list-group 替代,但需重写部分 Bootstrap 样式真正麻烦的不是写几行 CSS,而是得时刻想着:序号属于视觉装饰,不能影响 tab 键顺序、屏幕阅读器播报,也不能在打印时多出来一行空白——所有调整都得绕着这个边界走。