前端技术分享-码匠 极客编程技术分享

您当前位于:HTML+CSS ——> 清浮动 | 如何清除浮动

清浮动 | 如何清除浮动

2015/04/22 22:47:50 | 作者:HTML5学堂(码匠) | 分类:HTML+CSS | 关键词:清除浮动,浮动,伪元素,clear

清浮动 | 如何清除元素浮动

HTML5学堂(码匠):元素发生浮动,本身就会对文档产生影响,孕育而生的就是“清除浮动”。清浮动的方法有多种,可以使用空标签清浮动、br标签清浮动、overflow:hidden清浮动、改变元素展示类型、父级元素浮动等方法。

清除浮动后的效果:

HTML5 学堂 如何清除浮动 清除浮动后的效果

未清除浮动后的效果:

HTML5 学堂 如何清除浮动 未清除浮动后的效果

实例代码(未清除浮动):

  1. <!doctype html>
  2. <html>
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>梦幻雪冰</title>
  6.     <link rel="stylesheet" href="reset.css">
  7.     <style>
  8.         .main div {
  9.             float: left;
  10.             width: 200px;
  11.             height: 200px;
  12.             margin-right: 20px;
  13.             background: #fcf;
  14.         }
  15.         .footer {
  16.             width: 420px;
  17.             height: 100px;
  18.             background: red;
  19.         }
  20.     </style>
  21. </head>
  22. <body>
  23.     <div class="wrap">
  24.         <div class="main">
  25.             <div>梦幻雪冰</div>
  26.             <div>独行冰海</div>
  27.         </div>
  28.         <div class="footer"></div>    
  29.     </div>
  30. </body>
  31. </html>

解析:页面开发的时候可以为父级标签添加固定高度,但是有时希望内容能够撑开高度(比如内容不固定的时候)。对于不浮动的元素来说,它们是能够撑开外部div的高度的,但是一旦浮动,元素脱离文档流,父级div就相当于没有了内容(上面的例子中类名为main的高度为0了)。这时是没有办法实现内容撑开高度的。此时需要进行清除浮动对布局造成的一系列影响,所以叫清浮动。(不要误解成把浮动清除了,元素就没有浮动了,不是同一概念)。

欢迎沟通交流~HTML5学堂

清除浮动有很多种,如何进行选择清除浮动了?

今天给大家分享的是清浮动的具体代码实现,主要是帮助大家理解哪一种清除浮动比较好,辨析它们的优缺点而已。

一:空标签清浮动

  1. <!doctype html>
  2. <html>
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>梦幻雪冰</title>
  6.     <link rel="stylesheet" href="reset.css">
  7.     <style>
  8.         .main div {
  9.             float: left;
  10.             width: 200px;
  11.             height: 200px;
  12.             margin-right: 20px;
  13.             background: #fcf;
  14.         }
  15.         .footer {
  16.             width: 420px;
  17.             height: 100px;
  18.             background: red;
  19.         }
  20.         .clear {
  21.             clear: both;
  22.  
  23. /*消除默认行高的影响*/
  24.             height: 0;
  25.         }
  26.     </style>
  27. </head>
  28. <body>
  29.     <div class="wrap">
  30.         <div class="main">
  31.             <div>梦幻雪冰</div>
  32.             <div>独行冰海</div>
  33.             <p class="clear"></p>
  34.         </div>
  35.         <div class="footer"></div>    
  36.     </div>
  37. </body>
  38. </html>

二:br标签清除浮动

  1. <!doctype html>
  2. <html>
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>梦幻雪冰</title>
  6.     <link rel="stylesheet" href="reset.css">
  7.     <style>
  8.         .main div {
  9.             float: left;
  10.             width: 200px;
  11.             height: 200px;
  12.             margin-right: 20px;
  13.             background: #fcf;
  14.         }
  15.         .footer {
  16.             width: 420px;
  17.             height: 100px;
  18.             background: red;
  19.         }
  20.     </style>
  21. </head>
  22. <body>
  23.     <div class="wrap">
  24.         <div class="main">
  25.             <div>梦幻雪冰</div>
  26.             <div>独行冰海</div>
  27.             <!-- br标签自带的属性 -->
  28.             <br clear="all" />
  29.         </div>
  30.         <div class="footer"></div>    
  31.     </div>
  32. </body>
  33. </html>

欢迎沟通交流~HTML5学堂

三:父元素设置overflow:hidden

  1. <!doctype html>
  2. <html>
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>梦幻雪冰</title>
  6.     <link rel="stylesheet" href="reset.css">
  7.     <style>
  8.         .main {
  9.             overflow: hidden;
  10.         }
  11.         .main div {
  12.             float: left;
  13.             width: 200px;
  14.             height: 200px;
  15.             margin-right: 20px;
  16.             background: #fcf;
  17.         }
  18.         .footer {
  19.             width: 420px;
  20.             height: 100px;
  21.             background: red;
  22.         }
  23.     </style>
  24. </head>
  25. <body>
  26.     <div class="wrap">
  27.         <div class="main">
  28.             <div>梦幻雪冰</div>
  29.             <div>独行冰海</div>
  30.         </div>
  31.         <div class="footer"></div>    
  32.     </div>
  33. </body>
  34. </html>

四:父元素设置overflow:auto

  1. <!doctype html>
  2. <html>
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>梦幻雪冰</title>
  6.     <link rel="stylesheet" href="reset.css">
  7.     <style>
  8.         .main {
  9.             overflow: auto;
  10.         }
  11.         .main div {
  12.             float: left;
  13.             width: 200px;
  14.             height: 200px;
  15.             margin-right: 20px;
  16.             background: #fcf;
  17.         }
  18.         .footer {
  19.             width: 420px;
  20.             height: 100px;
  21.             background: red;
  22.         }
  23.     </style>
  24. </head>
  25. <body>
  26.     <div class="wrap">
  27.         <div class="main">
  28.             <div>梦幻雪冰</div>
  29.             <div>独行冰海</div>
  30.         </div>
  31.         <div class="footer"></div>    
  32.     </div>
  33. </body>
  34. </html>

五:父元素浮动

  1. <!doctype html>
  2. <html>
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>梦幻雪冰</title>
  6.     <link rel="stylesheet" href="reset.css">
  7.     <style>
  8.         .main {
  9.             float: left;
  10.         }
  11.         .main div {
  12.             float: left;
  13.             width: 200px;
  14.             height: 200px;
  15.             margin-right: 20px;
  16.             background: #fcf;
  17.         }
  18.         .footer {
  19.             width: 420px;
  20.             height: 100px;
  21.             background: red;
  22.         }
  23.     </style>
  24. </head>
  25. <body>
  26.     <div class="wrap">
  27.         <div class="main">
  28.             <div>梦幻雪冰</div>
  29.             <div>独行冰海</div>
  30.         </div>
  31.         <div class="footer"></div>    
  32.     </div>
  33. </body>
  34. </html>

效果:

HTML5 学堂 如何清除浮动

注释:使得与父元素相邻的元素的布局会受到影响(影响到了类名为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>独行冰海</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>独行冰海</div>
  •         </div>
  •         <div class="footer"></div>    
  •     </div>
  • </body>
  • </html>

相关文章推荐

浮动元素的基本特性

为何要清除浮动

br清浮动的原理与clear:both的兼容

position 定位的基本知识

欢迎沟通交流~HTML5学堂

微信公众号,HTML5学堂,码匠,原创文章,WEB前端,技术分享

HTML5学堂

原创前端技术分享

HTML5学堂,HTML5,WEB,前端,视频课程,技术视频,学习视频,面试,JS

原创视频课程

用心打造精品课程

微信小程序,决胜前端,面试题,面试题集合,前端,HTML5,真题

小程序-决胜前端

前端面试题宝库

原创书籍,学习书籍,书籍推荐,HTML5布局之路,HTML5,WEB前端

HTML5布局之路

非传统模式讲解前端