前几天被人问,「如何把元素固定在容器底部」。(本来想直接把 demo 地址给他,结果没找到,那么今天我们来补一下)
想法&思路
如果是页面底部,我们可以直接 position: fixed;bottom: 0;
基于浏览器定位直接实现。
但是他要的效果是基于父级容器,那么我们必须要使用其他手段来定位了
-
relative
来限制absolute
,然后bottom: 0
,但是在内容过长的时候会导致显示异常。所以我们需要做内部滚动。 - 如果做内部滚动,那么我们只要可以撑开盒子即可。不需要绝对定位了
使用 flex 实现
- 父级使用 flex 布局,column 垂直排列。
- 父级定高(height、maxHeight),
.content
子级flex:auto;
自动撑开。 或者.content
做高度限制。 -
footer 可以使用 absolute 加 padding 。或者完全依赖文档流布局都可以
123456789101112131415.demo
1
{
position
:
relative
;
padding-bottom
:
40px
;
display
: inline-
flex
;
flex-direction
: column;
}
.demo
1
.footer{
position
:
absolute
;
bottom
:
0
;
left
:
0
;
right
:
0
;
margin
:
0
;
}
.demo
1
.content{
overflow
:
auto
;
}
calc 实现
如果不使用 flex ,那么我们可以用 calc 来减去 header 和 footer 空间。
1 2 3 4 5 6 7 | .demo 3 { position : relative ; } .demo 3 .content{ overflow : auto ; max-height : calc( 100% - 40px ); } |
absolute 实现
如果 calc 兼容性不太好,那么还可以使用 absolute 将所有元素都脱离文档流。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | .demo 4 { position : relative ; } .demo 4 .header,.demo 4 .footer{ position : absolute ; margin : 0 ; top : 0 ; left : 0 ; right : 0 ; } .demo 4 .footer{ top : auto ; bottom : 0 ; } .demo 4 .content{ overflow : auto ; height : 100% ; padding-top : 30px ; padding-bottom : 30px ; margin : 0 ; box-sizing : border-box ; } |
到此这篇关于css如何把元素固定在容器底部的四种方式的文章就介绍到这了,更多相关css元素固定底部内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章,希望大家以后多多支持IT俱乐部!