乐趣区

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

当我们在写页面时经常会遇到页面内容少的时候,footer 会戳在页面中间或什么?反正就是不在最底部显示,反正就是很难看,下面要讲的布局就是解决如何使元素粘住浏览器底部,
方法一:footer 高度固定 + 绝对定位
html
<div class=”dui-container”>
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>
</div>

CSS
.dui-container{
position: relative;
min-height: 100%;
}
main {
padding-bottom: 100px;
}
header, footer{
line-height: 100px;
height: 100px;
}
footer{
width: 100%;
position: absolute;
bottom: 0
}

查看效果
方法二:在主体 content 上的下边距增加一个负值等于底部高度
html
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS
html, body {
height: 100%;
}
main {
min-height: 100%;
padding-top: 100px;
padding-bottom: 100px;
margin-top: -100px;
margin-bottom: -100px;
}
header, footer{
line-height: 100px;
height: 100px;
}

查看效果
方法三:将页脚的 margin-top 设为负数
html
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS
main {
min-height: 100%;
padding-top: 100px;
padding-bottom: 100px;
}
header, footer{
line-height: 100px;
height: 100px;
}
header{
margin-bottom: -100px;
}
footer{
margin-top: -100px;
}

查看效果
方法四:通过设置 flex,将 footer 的 margin-top 设置为 auto
html
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS
body{
display: flex;
min-height: 100vh;
flex-direction: column;
}
header,footer{
line-height: 100px;
height: 100px;
}
footer{
margin-top: auto;
}

查看效果
方法五:通过函数 calc() 计算内容的高度
html 代码
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS 代码
main{
min-height: calc(100vh – 200px); /* 这个 200px 是 header 和 footer 的高度 */
}
header,footer{
height: 100px;
line-height: 100px;
}

查看效果
方法六:通过设置 flexbox,将主体 main 设置为 flex
html
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS 代码
body{
display: flex;
min-height: 100vh;
flex-direction: column;
}
main{
flex: 1
}

查看效果
方法七:使用 grid 布局
Html 代码
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS 代码
html {
height: 100%;
}
body {
min-height: 100%;
display: grid;
grid-template-rows: auto 1fr auto;
}
.footer {
grid-row-start: 3;
grid-row-end: 4;
}

查看效果
方法八:display-*
html
<header>Header</header>
<main>Content</main>
<footer>Footer</footer>

CSS
body {
min-height: 100%;
display: table;
width: 100%;
}
main {
display: table-row;
height: 100%;
}

查看效果

退出移动版