浮动与清除浮动的六种方法
css中,一共给我们了三种布局方式
标准文档流
浮动(float)
定位(postion)
在元素进行浮动后,会出现父元素没有高度的情况,下面的内容会直接弹到上面的div盒子下面, 这是因为元素浮动后脱离了标准流 ,父盒子无法检测到子元素,于是高度变成了0
我们需要清除浮动
清除浮动的本质是清除浮动元素造成的影响:浮动的子标签无法撑开父盒子的高度
注意:
方法1:固定宽高
给浮动的元素添加父级div盒子,再给父级盒子设置高度
方法2:一起浮动
父元素也添加浮动,这样父元素也脱离文档流
方法5:父级添加双伪元素
:after 方式是额外标签法的升级版。给父元素添加:
方法6.父盒子添加overflow: hidden;触发BFC
方法简单,常用
BFC Block fomatting context(块级格式化上下文),是一个独立的渲染区域,让处于 BFC 内部的元素与外部的元素相互隔离,使内外元素的定位不会相互影响。
简单来说:bfc是创建了一个单独的区域,容器外的元素绝对无法影响到bfc内部的元素
1、float的值不是none。
2、position的值不是static或者relative。
3、display的值是inline-block、table-cell、flex、table-caption或者inline-flex
4、overflow的值不是visible
在布局中经常出现,两个相邻的盒子,上面盒子设置了 margin-bottom: 20px,下面盒子设置了margin-top: 30px;本来期望是20+30=50px,但在使用时并不是求和,而是取最大值,最后变成了50px
这时我们可以设置bfc来实现隔离开元素,防止他们相互影响
解决方案
1.用一个大盒子包住下面的盒子,设置大盒子是padding-top
2.使用一个大盒子包住下面的盒子,设置是overlow,触发bfc
在PC端布局中,常见左侧宽度固定,右侧随浏览器的变化而自适应,通常是将左侧栏浮动来实现的,右侧使用block来自动填满内容,但是随着右侧内容满了,就会挤到左侧底部
但我们只要为右侧大盒子触发bfc,触发后就是一个单独的空间,绝对不会挤到左侧去
在布局中经常出现子元素浮动了,父元素检测不到子元素的高度而坍塌高度变成0,这时我们需要清除浮动,而原理就是用BFC形成一个独立的空间,而空间内的浮动元素也被重新计算高度撑开盒子