首页 > 开发 > CSS > 正文

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

2024-07-11 08:33:37
字体:
来源:转载
供稿:网友

当我们在写页面时经常会遇到页面内容少的时候,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{
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表