资讯专栏INFORMATION COLUMN

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

KitorinZero / 3108人阅读

摘要:当我们在写页面时经常会遇到页面内容少的时候,会戳在页面中间或什么反正就是不在最底部显示,反正就是很难看,下面要讲的布局就是解决如何使元素粘住浏览器底部,方法一高度固定绝对定位查看效果方法二在主体上的下边距增加一个负值等于底部高度


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

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

html

Header
Content
Footer

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
Content
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
Content
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
Content
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
Content
Footer

CSS代码

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

查看效果

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

html

Header
Content
Footer

CSS代码

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

查看效果

方法七: 使用grid布局

Html代码

Header
Content
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
Content
Footer

CSS

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

查看效果

作者: w3cbest前端开发
互动: 如有疑问可进群讨论
本文原创,著作权归作者所有。商业转载请联系@w3cbest前端开发获得授权,非商业转载请注明原链接及出处。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/53545.html

相关文章

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

    摘要:当我们在写页面时经常会遇到页面内容少的时候,会戳在页面中间或什么反正就是不在最底部显示,反正就是很难看,下面要讲的布局就是解决如何使元素粘住浏览器底部,方法一高度固定绝对定位查看效果方法二在主体上的下边距增加一个负值等于底部高度 showImg(https://segmentfault.com/img/bVbmX36?w=1140&h=641);当我们在写页面时经常会遇到页面内容少的时...

    lentrue 评论0 收藏0
  • CSS布局基础——(三栏布局)

    摘要:三栏布局浮动定位头部左边栏右边栏中间栏底部三栏布局浮动定位浮动布局效果缺点浮动元素会脱离文档流,如果在的内部还有其他元素,有可能会因为父元素的高度塌陷而导致问题。 前言 大家总是听到双飞翼布局和圣杯布局...也不知道是谁取的名字,我就叫三栏布局吧。虽然他们有些细微的区别,但本质上都是实现一个三栏布局,即左右两栏固定,中间自适应。 实现方案 网上随便一搜,全是实现方案,少到两三种,多到七...

    enda 评论0 收藏0
  • footer固定页面底部实现方法总结

    摘要:方法二高度固定负值代码头部中间内容底部信息代码此方法把之前的元素放在一个容器里面,形成了和并列的结构首先,设置的高度至少充满整个屏幕其次,设置最后一个子元素的值大于等于的值最后,设置的值和负值。方法一:footer高度固定+绝对定位 HTML代码: 头部 中间内容 底部信息 CSS代码: *{ margin:0; padding:0; } h...

    longshengwang 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<