清除浮动的七种方式方法(实例代码讲解)
2015-12-22 15:42
525 查看
今天给大家分享的是清除浮动的具体代码实现,主要是帮助大家理解哪一种清除浮动比较好,辨析它们的优缺点而已。清除浮动有很多种,如何进行选择清除浮动呢?E良师益友网就拿下面的一个例子来讲解。
实例代码(未清除浮动):
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
解析:页面开发的时候可以为父级标签添加固定高度,但是有时希望内容能够撑开高度(比如内容不固定的时候)。对于不浮动的元素来说,它们是能够撑开外部div的高度的,但是一旦浮动,元素脱离文档流,父级div就相当于没有了内容(上面的例子中类名为main的高度为0了)。这时是没有办法实现内容撑开高度的。此时需要进行清除浮动对布局造成的一系列影响,所以叫清浮动。(不要误解成把浮动清除了,元素就没有浮动了,不是同一概念)。
下面E良师益友网就为大家分析总结一下清除浮动的方法!
一:空标签清浮动
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
.clear {
clear: both;
/*消除默认行高的影响*/
height: 0;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
<p class="clear"></p>
</div>
<div class="footer"></div>
</div>
</body>
</html>
注释:上面用p标签进行空标签清浮动,当然可以用别的标签;如果用行元素的话需要进行转化为块,块元素就没有必要转化啦。
二:br标签清除浮动
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
<!-- br标签自带的属性 -->
<br clear="all" />
</div>
<div class="footer"></div>
</div>
</body>
</html>
三:父元素设置overflow:hidden
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
overflow: hidden;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
四:父元素设置overflow:auto
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
overflow: auto;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
五:父元素浮动
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
float: left;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
注释:使得与父元素相邻的元素的布局会受到影响(影响到了类名为footer的元素)。
六:父元素设置display:table
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
display: table;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
七:after 伪元素(不是伪类)
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
.clearfix:after {
clear:both;
display:block;
height:0;
content:"\200B";
}
.clearfix {
*zoom:1;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main clearfix">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
以上就是所有清除浮动的方法啦,至于具体用哪种方法,那就由你来定夺了!
实例代码(未清除浮动):
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
解析:页面开发的时候可以为父级标签添加固定高度,但是有时希望内容能够撑开高度(比如内容不固定的时候)。对于不浮动的元素来说,它们是能够撑开外部div的高度的,但是一旦浮动,元素脱离文档流,父级div就相当于没有了内容(上面的例子中类名为main的高度为0了)。这时是没有办法实现内容撑开高度的。此时需要进行清除浮动对布局造成的一系列影响,所以叫清浮动。(不要误解成把浮动清除了,元素就没有浮动了,不是同一概念)。
下面E良师益友网就为大家分析总结一下清除浮动的方法!
一:空标签清浮动
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
.clear {
clear: both;
/*消除默认行高的影响*/
height: 0;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
<p class="clear"></p>
</div>
<div class="footer"></div>
</div>
</body>
</html>
注释:上面用p标签进行空标签清浮动,当然可以用别的标签;如果用行元素的话需要进行转化为块,块元素就没有必要转化啦。
二:br标签清除浮动
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
<!-- br标签自带的属性 -->
<br clear="all" />
</div>
<div class="footer"></div>
</div>
</body>
</html>
三:父元素设置overflow:hidden
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
overflow: hidden;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
四:父元素设置overflow:auto
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
overflow: auto;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
五:父元素浮动
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
float: left;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
注释:使得与父元素相邻的元素的布局会受到影响(影响到了类名为footer的元素)。
六:父元素设置display:table
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main {
display: table;
}
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
七:after 伪元素(不是伪类)
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>清除浮动方法大全</title>
<link rel="stylesheet" href="reset.css">
<style>
.main div {
float: left;
width: 200px;
height: 200px;
margin-right: 20px;
background: #fcf;
}
.footer {
width: 420px;
height: 100px;
background: red;
}
.clearfix:after {
clear:both;
display:block;
height:0;
content:"\200B";
}
.clearfix {
*zoom:1;
}
</style>
</head>
<body>
<div class="wrap">
<div class="main clearfix">
<div>清除浮动方法大全</div>
<div>html学习</div>
</div>
<div class="footer"></div>
</div>
</body>
</html>
以上就是所有清除浮动的方法啦,至于具体用哪种方法,那就由你来定夺了!
相关文章推荐
- C++ string详解
- Spring 注解 @Resource和@Autowired
- eclipse打开后处于无响应状态
- Github 使用小结
- window 7 下用MyEclipse编写Java程序连接HBase时遇到的问题
- Maven构建SpringMVC项目详解
- 完美解决SSH项目Hibernate update时候org.springframework.dao.DuplicateKeyException
- QTP 遍历控件-例子
- Web Service开发
- C语言指针和数组基础
- Ruby rails 页面跳转(render和redirect_to)
- C# ——窗体和控件随着分辨率的变化自适应大小
- PHP soap 调用 JAVA发布的webservice
- VBA窗口乱了如何恢复默认设置
- Visual Studio 2010中的C++程序调用matlab程序代码 混合编程
- 用 eclipse 创建javafx 可以运行但是报错的解决方法
- python使用mysql数据库(转)
- 增量更新开发语言Java转型安卓移动开发的行进
- Java中byte转换int时与0xff进行与运算的原因
- PHP 5.6启动失败failed to open configuration file '/usr/local/php/etc/php-fpm.conf'