页面中的垂直中心div,带有粘性页脚

时间:2018-05-23 14:42:01

标签: javascript html css angular

我正在尝试在IE11中垂直对齐div。我试图使用@billbad here

的答案

我的例子与互联网上的许多其他例子之间的区别在于他们没有使用粘性页脚,我认为是导致我错误的原因。

HTML

<div class="wrapper">
<div class="art-header"></div>
<div class="outer-container">
    <div class="middle-container text-center">
        <div class="contner">
            <button type="button" class="btn btn-primary text-center" (click)="addLine()">Primary</button>
            <ul>
              <li *ngFor="let line of name" >
              {{ line }}
              </li>
            </ul>
        </div>
    </div>
</div>

</div>
<div class="footer">
    <div class="rmpm-footer">
    <p>Footer</p>
</div>
</div>

CSS

的一部分
 .contner {
  min-height: 242px;
  max-height: 100%;
  width: 604px;
  padding-top:10px;
  background-color: #FFFFFF;
  box-shadow: 0 1px 1px 1px rgba(0,0,0,0.1);
  padding-bottom: 12px;
  transition: max-height .4s;
  -webkit-transition: .4s;
  position: relative;
  margin-left: auto;
  margin-right: auto;

  margin-top: 40px;
}
.middle-container {
  display: table-cell;
  vertical-align: middle;

}
.outer-container {
  display: table;
  position: absolute;
  height: 100%;
  width: 100%;
}

实际上div没有很好地居中,并且页脚高度被调整大小。那不是我想要的。

预期的行为是当我添加行时,div仍然居中,然后当div变得大于初始页面高度时,页脚会下降。

我创建了一个stackblitz example,您可以直接检查我的代码。

1 个答案:

答案 0 :(得分:0)

尝试使用margin-top代替display: table-cell

.middle-container {
  margin-top: 40%;
}