我将背景颜色应用于<span>
标记,并在其上设置左右padding
。问题是:padding
仅应用于<span>
的左(开始)和右(结束),而不是每行的左(开始)和右(结束)。包裹在几行上。
如何将左右padding
应用于中间行?
h1 {
font-weight: 800;
font-size: 5em;
line-height: 1.35em;
margin-bottom: 40px;
color: #fff;
}
h1 span {
background-color: rgba(0, 0, 0, 0.5);
padding: 0 20px;
}
<h1><span>The quick brown fox jumps over the lazy dog.</span></h1>
答案 0 :(得分:45)
您可以使用值为box-decoration-break
的{{1}}属性。
clone
每个框片段都是使用指定的边框,填充和边距包装每个片段独立渲染的。 border-radius,border-image和box-shadow独立应用于每个片段。在每个片段中独立地绘制背景,这意味着具有背景重复:无重复的背景图像可以重复多次。 - MDN
请参阅caniuse.com
上的当前浏览器支持表<强> jsFiddle example 强>
box-decoration-break: clone;
h1 {
font-weight: 800;
font-size: 5em;
line-height: 1.35em;
margin-bottom: 40px;
color: #fff;
}
h1 span {
background-color: rgba(0, 0, 0, 0.5);
padding: 0 20px;
-webkit-box-decoration-break: clone;
box-decoration-break: clone;
}
答案 1 :(得分:8)
Multi-line-padded-text通过CSS技巧拯救
HTML
<div class="padded-multiline">
<h1>
<strong>
How do I add padding to subsequent lines of an inline text element?
</strong>
</h1>
</div>
CSS
.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 Tricks,以及其他许多提示
答案 2 :(得分:3)
聚会晚了一点,但是,您可以使用<p>
标签而不是<span>
,这样会将填充内容应用于所有行。
答案 3 :(得分:0)
通过设置line-height
来尝试下面的段落或标签的单行语句。
line-height: 1.3;
答案 4 :(得分:0)
您可能只能display: block
或display: inline-block