【发布时间】:2017-06-19 14:11:48
【问题描述】:
我根据 Matthew Pennell 的解决方案(codepen by CSS Tricks)创建了多行填充文本。在 Chrome 中一切看起来都很好,但在 Firefox 中,跨度元素的高度大于其祖先的高度。如果我为 Firefox 调整 vertical padding,在 Chrome 中也会出现同样的问题,反之亦然。
为什么会这样?这个问题的真正技术原因是什么?
HTML 代码:
<div class="padded-multiline">
<h1>
<strong>How do I add padding to subsequent lines of an inline text element?</strong>
</h1>
</div>
CSS 代码:
:root {
font-family: Arial, sans-serif;
font-size: 20px;
}
.padded-multiline {
line-height: 1.3;
padding: 2px 0;
border-left: 20px solid #c0c;
width: 400px;
margin: 20px auto;
}
.padded-multiline h1 {
background-color: #c0c;
padding: 4px 0;
color: #fff;
display: inline;
margin: 0;
}
.padded-multiline h1 strong {
position: relative;
left: -10px;
}
【问题讨论】:
-
您是否已重置 CSS,即浏览器默认设置是否会影响这一点?
-
Firefox 将 span 和其他元素 (strong/u/em) 视为具有自己行高的内联元素。正如@Paul 所说,您应该使用重置。
-
@Paul 使用 CSS 重置在codepen 上分叉,但重置无法修复它:c
标签: html css google-chrome firefox