目录
[1. 清除浮动](#1. 清除浮动)
[2. 清除浮动本质](#2. 清除浮动本质)
[3. 清除浮动](#3. 清除浮动)
[4. 清除浮动方法](#4. 清除浮动方法)
[4.1 额外标签法](#4.1 额外标签法)
[4.1.1 总结](#4.1.1 总结)
[4.2 父级添加 overflow](#4.2 父级添加 overflow)
[4.3 after 伪元素法](#4.3 after 伪元素法)
[4.4 双伪元素清除浮动](#4.4 双伪元素清除浮动)
[5 总结](#5 总结)
1. 清除浮动
data:image/s3,"s3://crabby-images/e62f6/e62f6756cc2110ff685e118ee7b49a8e4972173a" alt=""
data:image/s3,"s3://crabby-images/71c6a/71c6a55ac2de3531ed84b0fe671efe0bd25946ed" alt=""
data:image/s3,"s3://crabby-images/44c27/44c2731b72624ae127eda2e167b5f124bb0ea499" alt=""
这是上面的源代码:
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
/* 不给高度,只给宽度,其中的内容会撑开外面的大盒子 */
.box {
background-color: bisque;
width: 600px;
border: 5px red solid;
}
/* 添加浮动后,不给高度的大盒子高度为 0,因为浮动的元素不占有位置 */
.one,.two {
width: 200px;
height: 200px;
background-color: aquamarine;
float: left;
}
/* 布局再添加一个 footer,布局就会更加乱 */
.footer {
height: 200px;
background-color: burlywood;
}
</style>
</head>
<body>
<div class="box">
<div class="one">111</div>
<div class="two">222</div>
</div>
<div class="footer"></div>
</body>
</html>
2. 清除浮动本质
data:image/s3,"s3://crabby-images/f00fd/f00fd0213edf052e90b1fce67505833f591fb63f" alt=""
3. 清除浮动
data:image/s3,"s3://crabby-images/4acc5/4acc5fefe6db6a3a02579d172426f50b81b30820" alt=""
data:image/s3,"s3://crabby-images/9f01a/9f01a50478a3be0f4b5eef0ef1491c4bff5c8cf5" alt=""
data:image/s3,"s3://crabby-images/ad86e/ad86e34b1599b2bb3566bbfd239189f0ad7eb4a5" alt=""
4. 清除浮动方法
data:image/s3,"s3://crabby-images/f31f5/f31f58f2819519b66394c67efcb789e8b07eefb6" alt=""
4.1 额外标签法
data:image/s3,"s3://crabby-images/a9ed0/a9ed06b7c2ff3f3401cff545f5a57c9eaa209286" alt=""
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
/* 不给高度,只给宽度,其中的内容会撑开外面的大盒子 */
.box {
background-color: bisque;
width: 600px;
border: 5px red solid;
}
/* 添加浮动后,不给高度的大盒子高度为 0,因为浮动的元素不占有位置 */
.one,.two {
width: 200px;
height: 200px;
background-color: aquamarine;
float: left;
}
/* 布局再添加一个 footer,布局就会更加乱 */
.footer {
height: 200px;
background-color: burlywood;
}
.cle {
clear: both;
}
</style>
</head>
<body>
<div class="box">
<div class="one">111</div>
<div class="two">222</div>
<div class="cle"></div>
</div>
<div class="footer"></div>
</body>
</html>
4.1.1 总结
data:image/s3,"s3://crabby-images/7850c/7850c7d93a08058b6e2949d0e7c6036dda6a2b9f" alt=""
4.2 父级添加 overflow
data:image/s3,"s3://crabby-images/1fe1e/1fe1e341d23d0496f341e702e0042efbdbd7eda4" alt=""
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
/* 不给高度,只给宽度,其中的内容会撑开外面的大盒子 */
.box {
overflow: hidden;
background-color: bisque;
width: 600px;
border: 5px red solid;
}
/* 添加浮动后,不给高度的大盒子高度为 0,因为浮动的元素不占有位置 */
.one,.two {
width: 200px;
height: 200px;
background-color: aquamarine;
float: left;
}
.footer {
height: 200px;
background-color: burlywood;
}
</style>
</head>
<body>
<div class="box">
<div class="one">111</div>
<div class="two">222</div>
</div>
<div class="footer"></div>
</body>
</html>
4.3 after 伪元素法
data:image/s3,"s3://crabby-images/09382/0938237a1ea409d06703aba4060bdde992a03dd2" alt=""
data:image/s3,"s3://crabby-images/62ee9/62ee9242197a9c963f487b02136f82c96d91ee9c" alt=""
使用时直接复制以下代码即可:
html
.clearfix:after {
content:"";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
/* .clearfix {
*zoom: 1;
} */
4.4 双伪元素清除浮动
data:image/s3,"s3://crabby-images/fab46/fab46fdb82bd3f59ccfc6bd60308cc9cca314479" alt=""
使用时直接复制以下代码即可:
html
.clearfix:before,.clearfix:after {
content: "";
display: table;
}
.clearfix:after {
clear: both;
}
/* .clearfix {
*zoom: 1;
} */
5 总结
data:image/s3,"s3://crabby-images/7df64/7df641a823ea32d096c4c263fd270fa0baad8b37" alt=""
data:image/s3,"s3://crabby-images/aa774/aa774c4883b8e5c23fb005dfca91e198a1ef29c3" alt=""