系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 网页制作 > CSS > 详细页面

详解八种方法实现CSS页面底部固定

时间:2019-12-07来源:系统城作者:电脑系统城

当我们在写页面时经常会遇到页面内容少的时候,footer会戳在页面中间或什么?反正就是不在最底部显示,反正就是很难看,下面要讲的布局就是解决如何使元素粘住浏览器底部,

方法一:footer高度固定+绝对定位

html


 
  1. <div class="dui-container">
  2. <header>Header</header>
  3. <main>Content</main>
  4. <footer>Footer</footer>
  5. </div>

CSS


 
  1. .dui-container{
  2. position: relative;
  3. min-height: 100%;
  4. }
  5. main {
  6. padding-bottom: 100px;
  7. }
  8. header, footer{
  9. line-height: 100px;
  10. height: 100px;
  11. }
  12. footer{
  13. width: 100%;
  14. position: absolute;
  15. bottom: 0
  16. }

查看效果

方法二:在主体content上的下边距增加一个负值等于底部高度

html


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS


 
  1. html, body {
  2. height: 100%;
  3. }
  4. main {
  5. min-height: 100%;
  6. padding-top: 100px;
  7. padding-bottom: 100px;
  8. margin-top: -100px;
  9. margin-bottom: -100px;
  10. }
  11. header, footer{
  12. line-height: 100px;
  13. height: 100px;
  14. }

查看效果

方法三:将页脚的margin-top设为负数

html


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS


 
  1. main {
  2. min-height: 100%;
  3. padding-top: 100px;
  4. padding-bottom: 100px;
  5. }
  6. header, footer{
  7. line-height: 100px;
  8. height: 100px;
  9. }
  10. header{
  11. margin-bottom: -100px;
  12. }
  13. footer{
  14. margin-top: -100px;
  15. }

查看效果

方法四: 通过设置flex,将footer的margin-top设置为auto

html


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS


 
  1. body{
  2. display: flex;
  3. min-height: 100vh;
  4. flex-direction: column;
  5. }
  6. header,footer{
  7. line-height: 100px;
  8. height: 100px;
  9. }
  10. footer{
  11. margin-top: auto;
  12. }
  13.  

查看效果

方法五: 通过函数calc()计算内容的高度

html代码


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS代码


 
  1. main{
  2. min-height: calc(100vh - 200px); /* 这个200px是header和footer的高度 */
  3. }
  4. header,footer{
  5. height: 100px;
  6. line-height: 100px;
  7. }

查看效果

方法六: 通过设置flexbox,将主体main设置为flex

html


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS代码


 
  1. body{
  2. display: flex;
  3. min-height: 100vh;
  4. flex-direction: column;
  5. }
  6. main{
  7. flex: 1
  8. }

查看效果

方法七: 使用grid布局

Html代码


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS代码


 
  1. html {
  2. height: 100%;
  3. }
  4. body {
  5. min-height: 100%;
  6. display: grid;
  7. grid-template-rows: auto 1fr auto;
  8. }
  9. .footer {
  10. grid-row-start: 3;
  11. grid-row-end: 4;
  12. }

查看效果

方法八: display-*

html


 
  1. <header>Header</header>
  2. <main>Content</main>
  3. <footer>Footer</footer>

CSS


 
  1. body {
  2. min-height: 100%;
  3. display: table;
  4. width: 100%;
  5. }
  6. main {
  7. display: table-row;
  8. height: 100%;
  9. }

查看效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

分享到:

相关信息

  • 纯CSS实现具有渐变和圆角的彩色边框

    传统的灰色纯色边框你是不是觉得太难看了?你是否想设计一些精美的边框,例如渐变、圆角、彩色的边框?那你来对地方了,本文将介绍如何用纯CSS就能实现具有渐变和圆角的彩色边框...

    2023-03-06

  • css圆角三角形的实现代码

    今天给大家带来一个如何实现圆角三角形的方案,这个方案虽然可以实现,但是也是借助拼凑等方式来实现的,假如想一个div来实现圆角三角形,还是比较困难的。之前文章讲了如何实现对话框,里面介绍了三角形的实现方式。今天讲讲...

    2023-03-06

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载