
当为元素添加 `box-shadow` 时,若其 `display` 属性在悬停时才设置为 `inline-block`,会导致布局重排,使下方文本跳动;正确做法是将 `display: inline-block` 提前定义在常态样式中。
这个问题的本质是布局不稳定(layout shift):原始代码中,butto:hover 新增了 display: inline-block,而常态下该元素默认为 display: inline(自定义标签无浏览器默认样式,实际按 inline 处理)。inline 元素不参与块级格式化上下文,不占据独立行框;一旦切换为 inline-block,它会获得“块级盒子”的渲染特性(如支持 box-shadow、vertical-align 等),同时影响行内流的基线对齐和高度计算,从而挤压或推移后续内容(如
标签)。
✅ 正确解法是提前声明稳定的显示模式:
butto {
border: none;
outline: none;
background-color: white;
padding: 2px;
cursor: default;
display: inline-block; /* ✅ 关键:始终为 inline-block */
}
butto:hover {
background-color: #e3e3e3;
box-shadow: 2px 2px grey; /* 不再触发 display 变更 */
}这样,元素在常态与悬停时都保持相同的盒模型类型,box-shadow 仅作为视觉层叠加效果(不占文档流空间),不会引起重排(reflow),下方
Text below!
将完全保持静止。⚠️ 补充注意事项:
- 自定义 HTML 标签(如
)需确保在现代浏览器中被识别为未知但合法元素(HTML5 允许任意小写自定义标签),但建议配合 role="button" 和 tabindex="0" 提升可访问性; - 若需更严格的语义化,推荐使用标准
- box-shadow 默认不影响布局尺寸,但若搭配 transform 或 margin 动画,仍需注意是否引入隐式合成层或重绘开销。
总结:布局稳定性优先于样式渐变逻辑——所有影响盒模型的关键属性(display、position、float、width/height 等)应统一在常态规则中定义,悬停状态仅负责纯视觉增强(颜色、阴影、过渡动画等)。










