摘要:浮動框旁邊的行框被縮短,從而給浮動框留出空間,行框圍繞浮動框。不浮動的浮動的三浮動之于塊浮動的框可以向左或向右移動,直到它的外邊緣碰到包含框或另一個浮動框的邊框為止。
?
?
浮動元素以脫離標準流的方式來實現元素的向左或向右浮動,并且浮動元素還是在原來的行上進行浮動的。float浮動屬性的四個參數:left:元素向左浮動;right:元素向右浮動;none:默認值,元素不浮動;inherit:繼承父元素的float屬性值。
父元素是否注意到自己有個浮動的子div呢?
<div style="width: 400px; height: auto; border: 2px solid black;"> <div style="width: 50px; height: 100px; background-color: green; float: right;">div> 我才不知道有沒有浮動框,我只顯示文字的高度 div>
從中我們可以發現,處于標準流中的父div并不知道浮動元素的存在,而浮動元素卻知道它父元素的邊界,它一直向右浮動直到撞到了父框的右邊界為止。
?
<div style="width: 240px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 80px; background-color: red;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green; float: right;"> 框二 div> div>
?我們發現框二并沒有跑到框一這一行的右側去,而浮動到了原來這行的的右側。
?
下面我們一起逐步學習CSS中的浮動屬性float。
?
?
CSS參考手冊上對float的說明:
float 屬性定義元素在哪個方向浮動。以往這個屬性總應用于圖像,使文本圍繞在圖像周圍,不過在 CSS 中,任何元素都可以浮動。浮動元素會生成一個塊級框,而不論它本身是何種元素。
如果浮動非替換元素,則要指定一個明確的寬度;否則,它們會盡可能地窄。
?
浮動框雖然脫離了標準流,但標準流中的文本依舊會做相應的移動,為浮動框留出空間。浮動框旁邊的行框被縮短,從而給浮動框留出空間,行框圍繞浮動框。
因此,創建浮動框可以使文本圍繞圖像:
? ? ? ?
<div style="width: 350px; background-color: #33FFFF;"> <img src="http://h5ip.cn/ge0w" style="width: 100px; height: 100px; float: right;"> <span> 路飛性格積極樂觀,愛憎分明,而且十分重視伙伴,不甘屈居于他人之下,對任何危險的事物都超感興趣。和其他傳統的海賊所不同的是,他并不會為了追求財富而殺戮,而是享受著身為海賊的冒險和自由 span> div>
?
<span>雖然我先寫于浮動元素,但還是被擠到了右邊。。。span> <div style="width: 100px; height: 100px; background: blue; float: left;">div>
? 首先應當注意塊級框不等同于塊狀元素,塊級元素會獨占一行而塊級框卻不會,浮動元素產生的效果類似于行內塊元素。對行內非替換元素設置width和height是無效的,但生成浮動元素之后width和height將有效,并且不會多帶帶占一行,所以說它類似于行內塊元素。
?
<span style="width: 100px; height: 50px; background-color: #6699FF;"> 不浮動的span span> <span style="width: 100px; height: 50px; background-color: #33FFFF; float: left;"> 浮動的span span>
?
?
?
不浮動的div為塊級元素,各自獨占一行
<div style="width: 240px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 80px; background-color: red;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green;"> 框二 div> <div style="width: 80px; height: 80px; background-color: blue;"> 框三 div> div>
?
<div style="width: 240px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 80px; background-color: red; float: right;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green;"> 框二 div> <div style="width: 80px; height: 80px; background-color: blue;"> 框三 div> div>
?
當框 1 向左浮動時,它脫離文檔流并且向左移動,直到它的左邊緣碰到包含框的左邊緣。因為它不再處于文檔流中,所以它不占據空間,實際上覆蓋住了框 2,使框 2 從視圖中消失。
<div style="width: 240px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 80px; background-color: red; float: left;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green;"> 框二 div> <div style="width: 80px; height: 80px; background-color: blue;"> 框三 div> div>
?
如果把所有三個框都向左移動,那么框 1 向左浮動直到碰到包含框,另外兩個框向左浮動直到碰到前一個浮動框,這時父框的高度為0
<div style="width: 240px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 80px; background-color: red; float: left;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green; float: left;"> 框二 div> <div style="width: 80px; height: 80px; background-color: blue; float: left;"> 框三 div> div>
?
?
?如果包含框太窄,無法容納水平排列的三個浮動元素,那么其它浮動塊向下移動,直到有足夠的空間。
<div style="width: 200px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 80px; background-color: red; float: left;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green; float: left;"> 框二 div> <div style="width: 80px; height: 80px; background-color: blue; float: left;"> 框三 div> div>
?
如果浮動元素的高度不同,那么當它們向下移動時可能被其它浮動元素“卡住”
<div style="width: 200px; height: auto; border: solid 1px black;"> <div style="width: 80px; height: 100px; background-color: red; float: left;"> 框一 div> <div style="width: 80px; height: 80px; background-color: green; float: left;"> 框二 div> <div style="width: 80px; height: 80px; background-color: blue; float: left;"> 框三 div> div>
?
?
? 通過上面的介紹可以總結出浮動的兩個副作用:1.頁面塌陷,也就是子元素不能將父元素撐開;2.元素覆蓋,浮動元素不在標準流中因此可能會覆蓋標準流中的元素。四種解決方案如下:
?
這種方法用來解決父元素的頁面塌陷問題,應當注意的是,為保證父框的高度等于最高浮動元素的高度應當充分考慮浮動元素的邊框以及內外邊距。
?
<div style="width: 300px; height: 52px; border: solid 1px black;"> <div style="width: 80px; height: 50px; background-color: red; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: green; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: blue; float: left; border: solid 1px #FFF;">div> div>
?
?
這種方式治標不治本,當浮動子元素增加時,頁面塌陷問題重現
?
clear 屬性規定元素的哪一側不允許其他浮動元素。clear屬性的四個參數:none(默認值)、left、right、both;如果聲明為左邊或右邊清除,會使元素的上外邊框邊界剛好在該邊上浮動元素的下外邊距邊界之下。
none:允許兩邊都可以有浮動對象;left:不允許左邊有浮動對象;right:不允許右邊有浮動對象;both:不允許有浮動對象。
?
添加clear屬性之前
<div style="width: 300px; height: auto; border: solid 1px black; clear: both;"> <div style="width: 80px; height: 50px; background-color: red; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: green; border: solid 1px #FFF; clear: left; ">div> div>
添加之后
?
添加clear前
<div style="width: 300px; height: auto; border: solid 1px black; clear: both;"> <div style="width: 80px; height: 50px; background-color: red; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: green; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: blue; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: green; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: blue; float: left; border: solid 1px #FFF;">div> <div style=" clear: both;">div> div>
添加之后
?
<div style="width: 300px; height: auto; border: solid 1px black; clear: both; overflow: hidden; zoom: 1;"> <div style="width: 80px; height: 50px; background-color: red; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: green; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: blue; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: green; float: left; border: solid 1px #FFF;">div> <div style="width: 80px; height: 50px; background-color: blue; float: left; border: solid 1px #FFF;">div> div>
?
?overflow屬性是用來修剪溢出的元素,所以使用此種方案會使溢出元素被截掉
使用overflow前
<div style="width: 300px; height: auto; border: solid 1px black; clear: both; padding: 5px; overflow: hidden;"> <div style="width: 500px; height: 50px; background-color: red; border: solid 1px #FFF;?float: left;">div> div>
使用后
?zoom是IE瀏覽器專用的屬性,通過子元素的高度來設置父元素的高度,添加該屬性用來兼容IE瀏覽器
?
這是一種”以毒攻毒“的方法,因為父元素浮動后雖然消除了浮動子元素對其的影響,但父元素下面的元素就可能就會受該浮動父元素的影響。?
<div style="width: 300px; height: auto; border: solid 1px black; clear: both; float: left;"> <div style="width: 100px; height: 50px; background-color: red; float: left;">div> div> <div style="width: 200px; height: 100px; background-color: blue;">div>
?
這四種常用的清除浮動解決辦法可以根據實際情況進行使用,當然還有一些也比較好的解決辦法,例如使用before偽類清除浮動,等進一步學習之后再補充。
?
?
感謝博主謙行的博客:CSS布局 ——從display,position, float屬性談起以及W3School提供的學習資料!所學不深,如有錯誤或不足之處還望留言指出,十分感謝!
?
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/1184.html
摘要:布局涉及到的屬性常用屬性值此元素不會被顯示它和屬性不一樣。當所有父元素中的所有元素脫離文檔流之后,父元素將失去原有默認的內容高度浮動塌陷配合使用屬性規定元素的哪一側不允許其他浮動元素。 @(CSS技巧)[CSS, 布局] 深入學習CSS布局系列(一)布局常用屬性 一直感覺自己對CSS的各個屬性很了解,可是在前幾天一次面試后發現自己真的很多地方感覺自己知道,可是實際上自己并不是真的理解了...
摘要:深入布局定位與浮動在知識體系中,除了選擇器,樣式屬性等基礎知識外,布局相關的知識才是比較核心和重要的點。定位后,原來在文檔流中占據的位置,會被其他元素所占據。清除浮動的特殊應用清除浮動可以解決父元素高度塌陷問題。? 深入css布局(2) — 定位與浮動 ? ???? 在css知識體系中,除了css選擇器,樣式屬性等基礎知識外,css布局相關的知識才是css比較核心和重要的點。今天我們來深...
摘要:前端技術之詳解第四天一第三天的小總結盒模型,什么是盒子所有的標簽都是盒子。如果不在標準流,比如盒子都浮動了,那么兩個盒子之間是沒有塌陷現象的盒子居中的值可以為,表示自動。前端技術之_CSS詳解第四天 一、第三天的小總結 盒模型box model,什么是盒子? 所有的標簽都是盒子。無論是div、span、a都是盒子。圖片、表單元素一律看做文本。 盒模型有哪些組成: width、hei...
摘要:前段時間寫過一篇基礎知識之,當時對的理解不太準確,被慕課網多名讀者指出原文已修正,如有誤導實在抱歉。浮動的基礎知識浮動有個屬性左浮動右浮動不浮動繼承。浮動元素脫離了標準文檔流,文字和行級元素會環繞該元素,塊級元素則不受影響。 前段時間寫過一篇CSS基礎知識之position,當時對float的理解不太準確,被慕課網多名讀者指出(原文已修正,如有誤導實在抱歉)。現對float進行更深入的...
摘要:為了實現這個效果,我們需要清除浮動。元素被向下移動用于清除之前的左右浮動。塊格式化上下文對浮動定位與清除浮動都很重要。浮動定位和清除浮動時只會應用于同一個內的元素。且為了不影響接下來的文檔標準流,往往也要收尾做出清除浮動。以下從浮動到BFC的段落 摘自MDN 網絡開發者float 浮動float CSS屬性指定一個元素應沿其容器的左側或右側放置,允許文本和內聯元素環繞它。該元素從網頁的正常流...
閱讀 781·2021-11-09 09:47
閱讀 1568·2019-08-30 15:44
閱讀 1143·2019-08-26 13:46
閱讀 2107·2019-08-26 13:41
閱讀 1266·2019-08-26 13:32
閱讀 3772·2019-08-26 10:35
閱讀 3519·2019-08-23 17:16
閱讀 448·2019-08-23 17:07