跳至主要內容

Sticky Footer

Mr.LRHCSS布局CSS大约 2 分钟

Sticky Footer

  • 如果页面内容不足够长时,页脚固定在浏览器窗口的底部。
  • 如果页面内容足够长时,页脚固定在页面的最底部。但如果页面内容不够长,置底的页脚就会保持在浏览器窗口底部。

sticky_footer

将内容部分的底部外边距设为负数

把内容部分最小高度设为100%,再利用内容部分的负底部外边距值来达到当高度不满时,页脚保持在窗口底部,当高度超出则随之推出的效果。

<body>
  <div class="wrapper">
    content
    <div class="push"></div>
  </div>
  <footer class="footer"></footer>
</body>

<style>
html, body {
  height: 100%;
  margin: 0;
}

.wrapper {
  min-height: 100%;
  margin-bottom: -50px; /* 等于footer的高度 */
}

.footer, .push {
  height: 50px;
}
</style>

这个方法需要容器里有额外的占位元素(如 .push)

注意:.wrappermargin-bottom 值需要和 .footer 的负的 height 值保持一致,这一点不太友好。

将页脚的顶部外边距设为负数

给内容外增加父元素,并让内容部分的底部内边距与页脚高度的值相等。

<body>
  <div class="content">
    <div class="content-inside">content</div>
  </div>
  <footer class="footer"></footer>
</body>

<style>
html, body {
  height: 100%;
  margin: 0;
}

.content {
  min-height: 100%;
}

.content-inside {
  padding: 20px;
  padding-bottom: 50px;
}

.footer, .push {
  height: 50px;
  margin-top: -50px;
}
</style>

使用flexbox弹性盒布局

<body>
  <div class="content">
    content
  </div>
  <footer class="footer"></footer>
</body>

<style>
html {
  height: 100%;
}

body {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.content {
  flex: 1;
}
</style>

absolute

<div class="wrapper">
  <div class="content">
    <!-- 页面主体内容区域 -->
  </div>
  <div class="footer">
    <!-- 需要做到 Sticky Footer 效果的页脚 -->
  </div>
</div>

<style>
html, body {
  height : 100 %;
}

.wrapper {
  position: relative;
  min-height: 100 %;
  padding-bottom: 50px;
  box-sizing: border-box;
}

.footer {
  position: absolute;
  bottom: 0;
  height: 50px;
}
</style>

需指定 htmlbody 100% 的高度,且 contentpadding-bottom 需要与 footerheight 一致

calc

通过计算函数 calc 计算(视窗高度 - 页脚高度)赋予内容区最小高度,不需要任何额外样式处理,代码量最少、最简单。

<div class="wrapper">
  <div class="content">
    <!-- 页面主体内容区域 -->
  </div>
  <div class="footer">
    <!-- 需要做到 Sticky Footer 效果的页脚 -->
  </div>
</div>

<style>
.content {
  min-height: calc(100vh - 50px);
}

.footer {
  height: 50px;
}
</style>

footer 的高度值需要与 content 其中的计算值一致。

table

<div class="wrapper">
  <div class="content">
    <!-- 页面主体内容区域 -->
  </div>
  <div class="footer">
    <!-- 需要做到 Sticky Footer 效果的页脚 -->
  </div>
</div>

<style>
html, body {
  height: 100%;
}

.wrapper {
  display: table;
  width: 100%;
  min-height: 100%;
}

.content {
  display: table-row;
  height: 100%;
}
</style>

注意:使用 table 方案存在一个比较常见的样式限制,通常 marginpaddingborder 等属性会不符合预期。 不建议使用这个方案。问题解决方式为:别把其他样式写在 table 上。

使用Grid网格布局

<body>
  <div class="content">
    content
  </div>
  <footer class="footer"></footer>
</body>

<style>
html {
  height: 100%;
}

body {
  min-height: 100%;
  display: grid;
  grid-template-rows: 1fr auto;
}

.footer {
  grid-row-start: 2;
  grid-row-end: 3;
}
</style>

参考:

上次编辑于:
贡献者: lrh21g