真正可靠的做法是用 display: flex + justify-content: space-between 配合明确的容器宽度控制;每个 .step 设 flex: 0 0 auto,避免拉伸变形;连线推荐使用显式 .connector 元素或容器级伪元素精确定位。
直接给 .step 设置 flex: 1 或 width: 25% 在不同屏幕下容易错位,尤其当步进器总数量动态变化(比如 3 步 vs 5 步)时,固定分栏会撑开或压缩文字。真正可靠的做法是用 display: flex + justify-content: space-between 配合明确的容器宽度控制。
实操建议:
立即学习“前端免费学习笔记(深入)”;
display: flex 和 justify-content: space-between,不依赖子项 flex 比例.step 用 flex: 0 0 auto,避免被 Flexbox 拉伸变形max-width(如 max-width: 600px)防止在大屏上过度拉宽连线flex-direction: column + align-items: center,此时连线改用 ::before 垂直居中伪元素伪元素默认相对于父元素定位,但步进器的连线需要连接两个相邻 step 的中心点。如果只对 .step 加 ::before,它只能画出单侧线段,且易受字体大小、内边距影响而偏移。
实操建议:
立即学习“前端免费学习笔记(深入)”;
.connector 元素,插在每对 step 之间(HTML 中显式写入),比纯伪元素更可控.steps-container 上用 ::after 绘制整体横线,再用 position: absolute + transform: translateX(-50%) 定位每个 step 的圆点height: 2px,背景色用 background-color 而非 border,避免盒模型干扰box-sizing: border-box,否则 padding 会让 width: 100% 计算失准小屏(如 max-width: 480px)时水平连线会挤压文字、降低可读性,此时应切换为垂直布局:step 垂直堆叠,连线改为从上一个 step 底部连到下一个 step 顶部。
实操建议:
立即学习“前端免费学习笔记(深入)”;
.steps-container 的 flex-direction:桌面端 row,移动端 column
.connector)在移动端设 display: none;改用每个 .step:not(:last-child)::after 画向下箭头或竖线content: ""、position: absolute、top: 100%、left: 50%、transform: translateX(-50%)
z-index 层级:确保连线在 step 圆点之下,但又不被后续内容遮盖步进器常需根据当前 active 步骤高亮对应圆点和已过连线。若每个状态都写死 background-color: #007bff,后期换主题色就得全局搜索替换。
实操建议:
立即学习“前端免费学习笔记(深入)”;
--step-active-color: #007bff 和 --step-inactive-color: #ccc,挂载在 :root 或组件容器上[data-step="2"].active .step-circle 这类属性选择器精准控制,而非依赖 class 层级嵌套过深.connector.active,配合 background-color: var(--step-active-color),无需 JS 操作样式字符串transition: all;只对 background-color 和 transform 做过渡,避免重排重绘性能问题padding、font-size、line-height 在各断点下保持比例一致,稍有偏差,连线就会看起来“没接上”。