我有一个包含三个<div><div>
在每个<div>元素中,都有一个<p>元素,其中包含文本和2个嵌套元素,以构成一个径向进度条。我需要将文本放在圆圈中间,并使用纯CSS进行响应。我需要这样的东西:

html - 如何在&lt;div&gt;内部将文本居中-LMLPHP

该代码具有缺陷,例如<p>内的<span>,但是我在你们提供的帮助下将其修复为新版本。



.radius-container div {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.radius-container div:first-child {
  margin-right: 1%;
}

.radius {
  padding-top: 11em;
  height: 30em;
  text-align: center;
  border: 1px solid #858280;
  display: block;
  border-radius: 50%;
  width: 100%;
}

.radius3 {
  position: relative;
  padding-top: 10%;
  height: 15em;
  width: 50%;
  text-align: center;
  border: 1px solid #858280;
  border-left: 0;
  border-bottom: 0;
  border-top-right-radius: 100%;
  display: block;
  margin-left: 15em;
}

.radius3 p {
  position: absolute;
  right: 50%;
  top: 65%;
}

<div class="radius-container">
  <div><span class="radius"><p>SERBIAN<br>100%</p></span></div>
  <div><span class="radius"><p>ENGLISH<br>100%</p></span></div>
  <div><span class="radius3"><p>GERMAN<br>25%</p></span></div>
</div>





另请参见此jsFiddle

最佳答案

在对此问题进行了长时间的研究之后,我找到了解决此类要求的通用解决方案。我为它感到骄傲,简洁而优雅:)

.center-element{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}


希望能有所帮助,如有任何疑问,请通知我。队友的欢呼声 :)

08-18 02:24
查看更多