HTML(WEB)开发day06

作者:gqk;

清除浮动:好比我们的浮动,有浮动开始,则就应该有浮动结束。

为什么要清除浮动?

由于浮动元素不再占用原文档流的位置,所以它会对后面的元素排版产生影响,为了解决这些问题,此时就需要在该元素中清除浮动。

准确地说,并不是清除浮动,而是清除浮动后造成的影响

如果浮动一开始就是一个美丽的错误,那么请用正确的方法挽救它。

清除浮动本质

清除浮动主要为了解决父级元素因为子级浮动引起内部高度为0 的问题

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
		div{
			border: 1px solid red;

		}
		.son1{
			height: 100px;
			width: 100px;
			background-color: pink;
			float: left;
		}
		.son2{
			height: 100px;
			width: 100px;
			background-color: yellow;
			float: left;
		}
		.foller{
			width: 400px;
			height: 100px;
			background-color: green;
		}
	</style>
</head>
<body>
	<div class="father">
		<div class="son1">1</div>
		<div class="son2">2</div>
	</div>
	<div class="foller">3</div>
</body>
</html>

  由于 浮动后 原有的位置没有了 所以产生一下的问题,

清除浮动的方法

在CSS中,clear属性用于清除浮动,其基本语法格式如下:

选择器{clear:属性值;}

额外标签法

html 是W3C推荐的做法是通过在浮动元素末尾添加一个空的标签例如 <div style=”clear:both”></div>,或则其他标签br等亦可。

优点: 通俗易懂,书写方便

缺点: 添加许多无意义的标签,结构化较差。 我只能说,w3c你推荐的方法我不接受,你不值得拥有。。

父级添加overflow属性方法

~~~css 可以给父级添加: overflow为 hidden|auto|scroll 都可以实现。 ~~~ 优点: 代码简洁

缺点: 内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素。

使用after伪元素清除浮动

:after 方式为空元素的升级版,好处是不用单独加标签了

使用方法:

```css .clearfix:after { content: ""; display: block; height: 0; clear: both; visibility: hidden; }

.clearfix {zoom: 1;} / IE6、7 专有 */ ```

项目案例: 云道页面

猜你喜欢

转载自www.cnblogs.com/520gqk/p/9437241.html