二维码

float

float

简介

float属性指定某个元素定位在容器的左侧或右侧,文字和其他行内元素紧挨在它的旁边。

1
2
3
h4  {
float: left;
}

如果对行内元素指定float属性,就相当于将这个行内元素变成块级元素。

float属性可以取三个值。

  • left:定位在容器的左侧
  • right:定位在容器的右侧
  • none:不采用浮动定位(默认值)

清理浮动

设置float属性以后,容器里面的行内元素(通常是文字)会紧贴浮动元素的边缘,进行布局。如果文字的长度小于浮动元素的高度,就会出现布局问题。

下面是一段 HTML 代码。

1
2
3
4
5
<div>
<h2>标题一</h2>
Hello World
</div>
<h3>标题二</h3>

其中的“标题一”是浮动的。

1
2
3
4
h2 {
height: 200px;
float: left;
}

由于Hello World的高度小于“标题一”的高度,导致紧跟在后面的“标题二”,不是出现在“标题一”的下方,而是在“标题一”的右侧。这时就需要清理浮动。

1
2
3
h3 {
clear: both;
}

clear属性可以取四个值。

  • left:左侧不能有浮动元素
  • right:右侧不能有浮动元素
  • both:两侧不能有浮动元素
  • none:默认值,不需要清理浮动

另一种情况是,容器内部的文本不希望紧贴浮动的元素,这时也可以使用clear属性进行清理浮动。

对容器的影响

如果一个容器里面所有子元素都是浮动的,就会导致这个容器变成一个空容器,高度缩为0。因为布局的时候,浮动的所有子元素是脱离父容器计算位置的,这导致渲染引擎认为这个容器是空元素。

解决这个问题,有三种方法。

(1)父容器也进行浮动。

1
2
3
4
.container-with-float{
float: left;
width: 100%;
}

(2)父容器添加overflow: hidden

1
2
3
.container-with-overflow{
overflow: hidden;
}

添加overflow: hidden以后,容器计算高度的时候,就会自动将浮动的子元素考虑在内。

(3)CSS 生成内容

CSS 生成内容以后,就不会被渲染引擎当成是一个空元素。

1
2
3
4
5
6
7
.container-with-generated-content:after{
content: ".";
display: block;
height: 0;
clear: both;
visibility: hidden;
}

还有另一种写法。

1
2
3
4
5
.grid:after {
content: "";
display: table;
clear: both;
}

本教程来自“网道项目”(wangdoc.com),采用知识共享 署名-相同方式共享 3.0协议