Css—float的影响和解决方案

html-css05

Css—float的影响和解决方案,第1张

推荐俩种依靠clear属于清除浮动的方法,推荐第二种,探究的记录在后面,赶时间的看个开头就好了。

1. 在受浮动坍塌的父级元素结束标签前,添加一个高宽为0的空div,然后设置 clear:both

2 .创建一个clearfix样式,并使用伪类元素 after 添加样式到父元素上

无论是块级元素还是行内元素设置了浮动之后都会生成一个块级框,并且可以编辑它的宽高,此时该浮动元素就脱离了文档流。举个例子,把网页看成一个三维的泳池,文档流在泳池底部,给文档流中一个元素设置了float之后,它就从这个网页的泳池底部浮动到了水上。此时同级的块级元素会无视float元素在网页上的位置进行布局。但是行内元素并不会被遮挡,而是像和它一起浮在水面上一样环绕这个浮动元素。

根据前面介绍,元素设置float后好像会从网页上浮一样,脱离文档流。这样的话,如果父级元素原本没设置高度,计划用子元素撑开父级元素。此时子元素因为float上浮,则父级元素的高度就会因为自身没设置而坍塌。

来个示例 ( 下文都是依据这个示例来讨论,故先给出HTML结构和CSS样式 ):

让我们再打开开发者工具具体看看

然后让我们把父元素也一同浮动看看

例如:

此时背景色为粉色的 ch2 就会被浮动的 背景色半透明的ch1 覆盖,但是ch2的字体还是环绕着ch1

如果让ch2 也浮动,则ch1 和 ch2 就相当于一同浮起到这个网页泳池的水面上。

另外,ch2 虽然不浮动起来时会被 同级ch1遮挡,但是ch2 它内部的行内元素却是环绕 ch1 的 ,同时 ch2 内部的块级元素还是会被浮动起来的ch1遮挡。

解决父元素高度坍塌的问题,其实可以给父元素指定个高度,但这样就没有父元素高度自适应的意义了;另外全部元素一起浮动也能解决父元素坍塌,子元素被遮挡的问题,但这本质上只是将所有元素一起浮动到顶端,并没有解决问题,反而还会影响另外的元素排列。下面介绍clear属性来清除浮动

那我们先来看看 clear 属性有什么用

我们稍稍改动一下上面的例子在 ch2 下加一个 p 标签然,然后改动一下 ch1 和 ch2 的样式让它们俩高度不一样。

若此时我们给p元素也加上浮动呢?

样例:

浮动,你可以理解为漂浮在空中,然后它后面紧挨着但未设置浮动的元素则仍然在地上,并且填补了漂浮元素原来在地上所占用的位置,也就是说,非浮动元素“钻”到浮动元素的下面去了,所以被盖住了。

要想避免这种情况,必须让浮动元素清除浮动,最简单的方式就是给浅蓝色div加一个 overflow:hidden ,这样它在空中漂浮的同时也保留了它原来在地面占用的位置,这样后面的其他非浮动元素就不会移动位置了,也就不会被遮盖。

css清除浮动float的三种方法总结:

不清除浮动的话,浮动层后面的非浮动内容就有可能被浮动层所覆盖,造成版面错乱,所以必须清除浮动。除非浮动层所在的位置是有固定的高度的,也就是说不管是否浮动它所占用的区域都不变,这样就无需清除。比如:

<div> <div style="float:leftwidth:100pxheight:100pxbackground-color:#f00"></div></div><div style="width:200pxheight:200pxbackground-color:#00f"></div>

可以看到蓝色框会被红色框覆盖(IE6-9中则不会,因为它不是标准浏览器)。清除浮动以后就不会了:

<div> <div style="float:leftwidth:100pxheight:100pxbackground-color:#f00"></div> <div style="clear:both"></div></div><div style="width:200pxheight:200pxbackground-color:#00f"></div>

或者给浮动层预留位置:<div style="width:100pxheight:100px"> <div style="float:leftwidth:100pxheight:100pxbackground-color:#f00"></div></div><div style="width:200pxheight:200pxbackground-color:#00f"></div>