如何将填充应用于多行文本中的每一行?

时间:2016-01-07 16:08:43

标签: html css css3

我将背景颜色应用于<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>

5 个答案:

答案 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: blockdisplay: inline-block