css浮动与清除浮动

html-css017

css浮动与清除浮动,第1张

css浮动(float:none | left | right)在网页布局中我们经常使用的属性,也是经常会出现Bug的地方。

首先我们要搞清楚为什么要用到float呢?

网页布局中块级元素,在页面中独占一行,自上而下排列,也就是传说中的文档流。

可是我们要实现左右模块该怎么实现,这就需要用到float了,当我把第三个设置左浮动

然后我们在测试第四个也设置左浮动

下面我将第二个和第四个右浮动

我们在测试将第三个浮动取消

可是在做网页布局的时候不想浮动元素影响遮盖下一个元素该怎么解决?

这个时候就需要我们清除浮动(clear:both | left | right)

上面的例子 希望第三个左浮动,第二个和第四个右浮动,第五个不受影响在最下面。

CSS清除浮动很多方式,可以使用:before和:after伪类来清除浮动,优点是不会增加页面dom元素,缺点是IE浏览器只支持IE8及其以上。

案例:

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形成一个独立的空间,而空间内的浮动元素也被重新计算高度撑开盒子