DIV+CSS 清除浮動是頁面佈局中常見的問題,相信各位高手也都有本身的方法,今天在這裏對常見的幾種方法進行總結(PS:談不上是原創,這裏是我本身作的概括總結,也是我本身內化的過程),但願對您可以有所幫助。感謝博客園平臺!---- 來自<一隻有夢想的前端小白>css
DIV+CSS 浮動效果是指,父元素在未定義高的狀況下,因爲子元素所有浮動脫離文本流,而形成父元素高的塌陷(PS:正常狀況下,父元素的高是由子元素撐起來);或者由於部分子元素的而浮動,脫離文本流而形成其餘元素的佈局錯亂的狀況。前端
DIV+CSS 清除浮動 常見的方法以下:bootstrap
一、給未加浮動的子元素的CSS添加 clear: both;若子元素都有浮動時,能夠新增長一個空的子元素,而且給其的CSS添加 clear: both;這樣能夠利用清除左右浮動的子元素從新撐起父元素的高,從而達到清除浮動的效果。代碼及效果以下:佈局
<style type="text/css"> .fl{float:left;} .demo{background:#ccc;} .item1{background:#F571E3;height:100px;width:100px;} .item2{background:#21B2F7;height:200px;width:100px;clear: both;} </style> </head> <body> <h2>用 clearfix 清除浮動</h2> <div class="demo"> <div class="fl item1"></div> <div class="item2"></div> </div> </body>
清除浮動前,item1左浮動的效果(此時父元素的高是被未浮動的item2元素的高撐開):spa
清除浮動前,item1右浮動的效果(此時父元素的高是被未浮動的item2元素的高撐開):3d
清除浮動後的效果(由於DIV是塊級元素,會獨佔一行,因此item2會在下面一行,此時父元素的高是被item1元素和item2元素的高撐開):code
二、子元素所有浮動時,給父元素的CSS添加 overflow: hidden;(子元素沒有所有浮動時,不浮動的元素會撐開父元素的高,可是因爲浮動元素形成的佈局應該再利用padding進行修改),可是此方法父元素不能改使用position進行定位,不然不起做用。代碼及效果以下:blog
<style type="text/css"> .fl{float:left;} .demo{background:#ccc;overflow: hidden;} .item1{background:#F571E3;height:100px;width:100px;} .item2{background:#21B2F7;height:200px;width:100px;} </style> </head> <body> <div class="demo"> <div class="fl item1"></div> <div class="fl item2"></div> </div> </body>
清除浮動前的效果,因爲父元素的高塌陷,因此背景 background:#ccc; 沒有起效果:博客
清除浮動後的效果:頁面佈局
三、給父元素加 僞類:after 和 zoom,代碼及效果以下:
<style type="text/css"> .fl{float:left;} .demo{background:#ccc;zoom: 1;} .demo:after{display:block;clear:both;content:"";visibility:hidden;height:0} .item1{background:#F571E3;height:100px;width:100px;} .item2{background:#21B2F7;height:200px;width:100px;} </style> </head> <body> <div class="demo"> <div class="fl item1"></div> <div class="fl item2"></div> </div> </body>
清除浮動前的效果,因爲父元素的高塌陷,因此背景 background:#ccc; 沒有起效果:
清除浮動後的效果:
四、若是是在使用bootstrapt,則能夠給其父元素添加class 爲 clearfix 的類,代碼及效果以下:
<style type="text/css"> .fl{float:left;} .demo{background:#ccc;} .item1{background:#F571E3;height:100px;width:100px;} .item2{background:#21B2F7;height:200px;width:100px;} </style> </head> <body> <div class="demo clearfix"> <div class="fl item1"></div> <div class="fl item2"></div> </div> </body>
清除浮動後的效果:
以上方法各有利弊,你們能夠根據本身的理解選擇使用,還有一些其餘的清除浮動的方法,例如讓父元素浮動、讓父元素 display:table 等等其餘,我的並不推薦使用。
但願以上的介紹對您能有所幫助,若有錯誤還請各位大神指正,感謝博客園平臺!----來自<一隻有夢想的前端小白>