整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          CSS中清除浮動的幾種方法,快來學習一下吧

          首先我們通過一張圖來解釋下元素浮動是什么樣的狀態。

          元素浮動情況

          上圖的html部分代碼為:

          html代碼

          css部分代碼為:

          css代碼

          通過上面的圖片可以看出,當內部的div設置float后,外部的元素的就會受到以下影響:

          • 背景不能顯示

          • 邊框不能被撐開

          • margin和padding設置的值不能正確顯示

          元素浮動的壞處

          如果不清除元素浮動的話,浮動層后面的非浮動層內容就有可能被覆蓋,造成頁面的排版混亂。

          例如在上面的例子中再加一個非浮動的div,就會發現該div被前面的三個浮動div覆蓋住。

          因為浮動,后面的div被覆蓋

          既然會出現這種情況,我們就應該設法清除掉元素的浮動。

          方法1-父級元素設定定高

          我們可以給父級元素.outer設置為定高,這樣就可以不影響后面的非浮動元素。.outer的樣式為:

          設置定高

          達到的效果為

          清楚浮動之后

          雖然這種方法可以清楚浮動,但是對父元素設置定高會有很多的限制,如果內層div的高度變化,則需要手動修改外層div的高度,相對來說有點麻煩,因此這種方法并不推薦。

          方法2-添加新元素,設置clear:both

          在父元素內部的末尾處添加一個新的div,并設置其clear: both;屬性。

          添加一個新的div

          該新增div的css屬性為:

          新增div的css屬性

          利用該方法同樣可以達到清楚浮動的效果,但是由于會新增DOM元素,這種方法也不推薦。

          方法3-父級元素使用overflow:hidden屬性

          在父級元素上使用overflow:hidden屬性,準確來說只要不給overflow屬性設置為visible都可以清除元素浮動。

          設置overflow: hidden

          使用這種方法可以少寫很多css樣式代碼,同時不會新增DOM元素,因此推薦使用這種方式。

          方法4-對父元素使用偽元素

          通過對父元素使用:after偽元素,同樣可以達到清除浮動的效果。

          偽元素清楚浮動

          以上方法在偽元素中,通過設置clear與overflow屬性來實現。方法4在實際的項目中使用的頻率最高,因此極大的推薦使用方法4來清除元素浮動。

          其他方法

          看到網上有的資料介紹,通過設置父元素為浮動,或者設置父元素為absolute定位,這兩種方法只是能顯示父元素而已,但父元素同樣會覆蓋到后面的非浮動元素,因此這兩種方法嚴格意義來說并不算清除浮動的方法。

          總結

          今天這篇文章主要介紹了幾種通過CSS來清除元素浮動的方法,你掌握了嗎?

          天這篇文章給大家介紹3種CSS清除浮動的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

          首先,這里就不講為什么我們要清楚浮動,反正不清除浮動事多多。

          下面我就講3種常用清除浮動的方法,夠用了。

          1、在浮動元素后面加一個空的div,并為它清除浮動

          html代碼:

          <div class="wrap">   <div class="float">浮動</div>   <div class="clear"></div>   <div class="nofloat">不想被浮動影響</div></div>

          css代碼:

          .wrap{  width:500px;  height:400px;  border:1px solid red;  margin:0 auto;}.float{  width:200px;  height:200px;  background:#ccc;  float:left;}.nofloat{    width:300px;    height:150px;    background:red;}

          現在雖然加了一個空的div,但是并沒有給它清除浮動,所以目前的效果就是第三個子元素.nofloat還是收到浮動的影響。

          OK,現在給.clear加上清除浮動:

          .clear{    clear:both;}

          刷新一下效果就出來了:

          PS:這種情況比較適合元素之間是垂直排列布局的,為了不受彼此浮動的影響。

          2、利用BFC特性清除浮動

          html代碼:

          <div class="wrap">   <div class="float">浮動</div>   <div class="nofloat">不想被浮動影響</div></div>

          css代碼:

          .wrap{  width:500px;  border:1px solid red;  margin:0 auto;  overflow:hidden;}.float{  width:200px;  height:200px;  background:#ccc;  float:left;}.nofloat{    width:300px;    height:150px;    background:red;    overflow:hidden;}

          效果是這樣的:

          這里父容器是沒有設置固定高度的,本來第一個子元素浮動之后,父元素的高度會塌陷到跟第二個子元素一樣高,但由于這里分別給第二個子元素和父元素都設置了overflow:hidden ,所以它們都生成了一個新的BFC區域,根據上文提供的BFC布局規則可以得知:BFC區域不會與float box 重疊;計算BFC高度時浮動元素的高度也參與計算。

          所以就得到清除浮動的效果。說得比較繞,但其實清除浮動得根據自己開發中的實際情況合理使用。

          3、使用:after偽元素,給浮動元素的父元素清除浮動

          html代碼:

          <div class="wrap">   <div class="float">浮動</div></div>

          css代碼:

          .wrap{  width:500px;  border:1px solid red;  margin:0 auto;}.float{  width:200px;  height:200px;  background:#ccc;  float:left;}

          此時子元素浮動了,脫離了文檔流,所以父元素高度酒塌陷了:

          可以看到父元素的邊框擠在一起了。

          OK,現在給父元素添加一個clearfix類:

          <div class="wrap clearfix">   <div class="float">浮動</div></div>
          .clearfix{    *zoom:1;}.clearfix:after{    content:'clear';    display:block;    height:0;    clear:both;    overflow:hidden;    visibility:hidden;}

          現在刷新后的效果就是:

          這種方法和BFC清除浮動個人用的比較多,實際開發中,其實這兩種就夠用了。

          好的,清除浮動我也就簡單地提到這里!

          以上就是CSS清除浮動的幾種方法的詳細內容。如果有什么錯誤的話,歡迎留言指正。

          動的目的:把多個盒子放在一行上

          清除浮動的目的:解決父盒子高度為0的問題

          清除浮動,也稱閉合浮動

          注:本文不兼容IE6

          未清除浮動實現情況:

          圖1

          清除后:

          圖2

          原代碼:

          復制代碼

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>清除浮動</title>

          <style type="text/css">

          .content{

          width:960px;

          margin:100px auto;

          border: 1px solid #ccc;

          }

          .left{

          width:400px;

          height: 200px;

          background-color: green;

          float: left;

          }

          .right{

          width: 400px;

          height: 200px;

          background-color: red;

          float: right;

          }

          </style>

          </head>

          <body>

          <div class="content">

          <div class="left"></div>

          <div class="right"></div>

          </div>

          </body>

          </html>

          復制代碼

          具體方法:

          1.額外標簽法

          在含浮動標簽后加兄弟盒子清除浮動

          例:

          復制代碼

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>清除浮動</title>

          <style type="text/css">

          .content{

          width:960px;

          margin:100px auto;

          border: 1px solid #ccc;

          }

          .left{

          width:400px;

          height: 200px;

          background-color: green;

          float: left;

          }

          .right{

          width: 400px;

          height: 200px;

          background-color: red;

          float: right;

          }

          .clearbox{

          clear:both;

          }

          </style>

          </head>

          <body>

          <div class="content">

          <div class="left"></div>

          <div class="right"></div>

          <div class="clearbox"></div>

          </div>

          </body>

          </html>

          復制代碼

          缺點:添加了許多空div

          2.給父盒子overflow:hidden

          觸發bfc模式(該名詞不懂請谷歌/百度,初學者可暫時略過),直接清除浮動

          復制代碼

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>清除浮動</title>

          <style type="text/css">

          .content{

          width:960px;

          margin:100px auto;

          border: 1px solid #ccc;

          overflow: hidden;

          }

          .left{

          width:400px;

          height: 200px;

          background-color: green;

          float: left;

          }

          .right{

          width: 400px;

          height: 200px;

          background-color: red;

          float: right;

          }

          .clearbox{

          clear:both;

          }

          </style>

          </head>

          <body>

          <div class="content">

          <div class="left"></div>

          <div class="right"></div>

          </div>

          </body>

          </html>

          復制代碼

          缺點:不可與position屬性配合使用

          3.偽元素法

          給父元素定義偽類:after(此處使用的是公共類clearfix)

          復制代碼

          .clearfix:after{

          content:"";/*內容為空*/

          visibility:hidden;/*將元素隱藏,但是在網頁中該占的位置還是占著*/

          display:block;/*變成塊級元素*/

          height:0;

          clear:both;/*清除浮動*/

          }

          復制代碼

          具體代碼:

          復制代碼

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>清除浮動</title>

          <style type="text/css">

          .clearfix:after{

          content:"";/*內容為空*/

          visibility:hidden;/*將元素隱藏,但是在網頁中該占的位置還是占著*/

          display:block;/*變成塊級元素*/

          height:0;

          clear:both;/*清除浮動*/

          }

          .content{

          width:960px;

          margin:100px auto;

          border: 1px solid #ccc;

          }

          .left{

          width:400px;

          height: 200px;

          background-color: green;

          float: left;

          }

          .right{

          width: 400px;

          height: 200px;

          background-color: red;

          float: right;

          }

          .clearbox{

          clear:both;

          }

          </style>

          </head>

          <body>

          <div class="content clearfix">

          <div class="left"></div>

          <div class="right"></div>

          </div>

          </body>

          </html>

          復制代碼

          缺點:IE8以上和非IE瀏覽器才支持

          4.雙偽元素法

          給父類加上偽類:before和:after

          復制代碼

          .clearfix:before,.clearfix:after{

          content:"";

          display:table;

          }

          .clearfix:after{

          clear:both;

          }

          復制代碼

          具體代碼:

          復制代碼

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>清除浮動</title>

          <style type="text/css">

          .clearfix:before,.clearfix:after{

          content:"";

          display:table;

          }

          .clearfix:after{

          clear:both;

          }

          .content{

          width:960px;

          margin:100px auto;

          border: 1px solid #ccc;

          }

          .left{

          width:400px;

          height: 200px;

          background-color: green;

          float: left;

          }

          .right{

          width: 400px;

          height: 200px;

          background-color: red;

          float: right;

          }

          .clearbox{

          clear:both;

          }

          </style>

          </head>

          <body>

          <div class="content clearfix">

          <div class="left"></div>

          <div class="right"></div>

          </div>

          </body>

          </html>

          復制代碼

          附:

          對于上述4種方法,優先推薦方法3和4,當然1和2也可,可根據具體情況使用。

          還有幾種亂七八糟的清除浮動方法,但是缺點多,故不提起.

          最后你覺得我們的文章對你有幫助,歡迎關注我,可以私信我:久伴,領取學習資料,在評論下方可以關注我的學習群,你可以隨時在上面向我們提問,把你在學習前端過程中所遇到的問題發給我們。我們每天都會按時回復大家的每一個問題,希望久伴可以伴隨你從入門到專家。


          主站蜘蛛池模板: 无码乱码av天堂一区二区| 国产免费一区二区三区| 一区二区三区四区精品视频| 国模精品一区二区三区视频| 99精品一区二区三区| 一区二区三区视频免费观看| 亚洲AV无码国产一区二区三区 | 亚洲一区精品无码| 国产一区二区三区免费视频| 呦系列视频一区二区三区| 日韩高清国产一区在线| 久久免费国产精品一区二区| 久久国产三级无码一区二区| 无码人妻AⅤ一区二区三区水密桃| 日韩视频一区二区在线观看| 亚洲乱码av中文一区二区| 极品人妻少妇一区二区三区 | 国产乱码精品一区二区三区香蕉 | 中文字幕久久亚洲一区| 国产福利电影一区二区三区,日韩伦理电影在线福 | 波多野结衣一区二区三区| 久久精品午夜一区二区福利 | 日本一区视频在线播放| 午夜视频久久久久一区| 亚洲av午夜精品一区二区三区| 日本精品夜色视频一区二区| 无码日韩人妻AV一区二区三区| 亚洲高清成人一区二区三区| 精品国产不卡一区二区三区| 国产一区三区二区中文在线| 久久久久久综合一区中文字幕| 无码精品一区二区三区在线| 激情内射亚洲一区二区三区爱妻| 亚洲欧美国产国产一区二区三区| 色综合视频一区二区三区44| 国产精品无码一区二区在线观| 性色AV一区二区三区无码| www.亚洲一区| 精品一区二区三区东京热 | 亚洲国产精品一区二区久久hs| 无码人妻精品一区二区三区夜夜嗨 |