垂直对齐div到未知高度div而不影响水平居中

时间:2017-08-17 13:59:50

标签: css

Desired layout

在上图中,有一个100%宽度和未知高度的红色div。高度由橙色div的高度加上一些填充物控制。

橙色div的高度和宽度由动态文本内容控制,我们提前不知道,但橙色div应该在红色div内水平居中,两侧宽度相等。

蓝色div将是固定的宽度和高度(比如50px x 50px,小于橙色div),并放在左侧。它有时是可见的,有时不是(由javascript控制 - 可见性或显示,无论哪种效果最好),但在任何一种情况下都不应影响橙色div的水平居中。但是,蓝色div的垂直中心应垂直对齐,以匹配橙色div的垂直中心。

我可以添加额外的div,或者更改为跨度的东西,类似的东西,但是此刻我尝试的任何东西都意味着当我需要蓝色时,橙色div的水平居中的流量考虑了蓝色div div完全取消了流程。

有什么想法吗?

2 个答案:

答案 0 :(得分:2)

您应该使用display: flexalign-items,将最小高度传递到您的容器也很重要。

我创造了一个快速的小提琴来解释我对你的理解。

看看这个(JSFiddle):



.container {
  width: 300px;
  padding-bottom: 20px;
  padding-top: 20px;
  border: solid 1px red;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
}

.inner {
  background: rgba(0, 0, 0, 0.5);
  width: 50%;
}

.fixed {
  position: fixed;
  left: 20px;
  border: solid 1px blue;
  height: 30px;
}

<div class="container">
  <div class="inner">
    Lorem Ipsum Lorem IpsumLorem IpsumLorem IpsumLorem IpsumLorem IpsumLorem Ipsum Lorem Ipsum Lorem IpsumLorem IpsumLorem IpsumLorem IpsumLorem IpsumLorem Ipsum Lorem Ipsum Lorem IpsumLorem IpsumLorem IpsumLorem IpsumLorem IpsumLorem Ipsum
  </div>
  <div class="fixed">
    fixed
  </div>
</div>
&#13;
&#13;
&#13;

答案 1 :(得分:1)

绝对定位蓝色div并使用transform将其居中。您需要在两个彩色div周围添加一个容器。

.red {
  border: 2px solid red;
  width: 100%;
}

.container {
  position: relative;
}

.blue {
  background-color: blue;
  border: 2px solid darkblue;
  width: 70px;
  height: 70px;
  position: absolute;
  left: 40px;
  top: 50%;
  transform: translate(0, -50%);
}

.yellow {
  background-color: yellow;
  border: 2px solid goldenrod;
  margin: 10px auto 50px;
  width: 120px;
  height: 200px; /* change me */
}
<div class="red">
  <div class="container">
    <div class="blue">
    </div>
    <div class="yellow">
    </div>
  </div>
</div>