高度塌陷以及解决方法

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_44313091/article/details/100022237

高度塌陷问题

在文档流中,父元素的高度默认被子元素撑开的,也就是说子元素多高父元素就多高,但是当为我们子元素设置浮动以后,子元素就会完全脱离文档流,此时会导致子元素无法撑开父元素的高度,导致父元素的高度塌陷。由于父元素的高度塌陷,则父元素下的所有元素都会向上移动,导致页面的布局混乱。

高度塌陷解决方法

以下提出的解决方案将会越来越优化,最后一个方法是最为推荐的一个方法。

一、我们可以将父元素的高度写死,以避免高度塌陷的问题。但是一旦高度写死,父元素的高度将不能自动适应子元素的高度,所以这种方案是不推荐使用的。

二、开启BFC属性

根据W3C的标准,在我们的页面中元素都有一个隐含的属性叫做“Block Formatting Context”,简称BFC,该属性可以设置打开或者关闭,默认是关闭的。当我们开启元素的BFC以后,元素会具有以下特性:

1.父元素的垂直外边距不会和子元素重叠

2.开启BFC的元素不会被浮动元素覆盖

3.开启BFC的元素可以包含浮动的子元素

如何开启元素的BFC:

1.设置元素的浮动: 这种方式开启虽然可以撑开父元素,但是会导致父元素的宽度丢失,而且这种方式也会导致下边的元素上移,不能解决问题。

2.设置元素的绝对定位

3.设置元素为inline-block: 可以解决问题,但是会导致宽度丢失,不推荐使用这种方式

4.将我们元素的overflow设置为非visible的值(推荐方式:将overflow设置为hidden是副作用最小的开启BFC的方式

注意:在IE6及以下的浏览器并不支持BFC,所以这种方式不能兼容IE6。在IE6中虽然没有BFC,但是具有另一个隐含的属性叫做hasLayout,该属性的作用和BFC类似,所以在IE6中,通过开启hasLayout属性来解决该问题。开启的方式有很多,我们直接使用一种副作用最小的方式,直接将元素的zoom值设置为1。zoom这个样式只在IE中支持,其他浏览器都不支持。

三、可以直接在高度塌陷的父元素的最后,添加一个空白的div

由于添加的div并没有浮动,所以他是可以撑开父元素的高度的,再对其进行清除浮动,可以通过空白的div来撑开父元素的高度,基本没有副作用。使用这种方式,虽然可以解决问题,但是会在页面中添加多余的结构。

四、通过after伪类来选中父元素的后面

可以通过after伪类向元素的的最后添加一个空白的块元素,然后对其清除浮动,这样做和添加div的原理一样,可以达到相同的效果,而且不会再页面中添加多余的div,这是我们最为推荐使用的方式,几乎没有副作用。

注意:在IE6及以下浏览器不支持after伪类,所以在IE6及以下浏览器还需要使用hasLayout来处理。

.clearfix:after{
		/*添加一个内容*/
		content: "";
	/*转成成一个块元素*/
		display: block;
		/*清除两侧浮动*/
		clear: both;
			}

 

猜你喜欢

转载自blog.csdn.net/qq_44313091/article/details/100022237