## 2.4 浮動和清除浮動
### 1.什么是浮動
我們可以用一句話描述浮動的元素的特點:**浮動元素會脫離文檔流并向左/向右浮動,直到碰到父元素或者另一個浮動元素。**
```css
div{float:left/right};
```
**浮動會脫離文檔流**
脫離文檔,也就是說浮動不會影響普通元素的布局。我們可以直接理解成,浮動的元素在普通文檔流的上面一層,更靠近屏幕的上層。

* 默認三個設置了寬高的`block`元素,本來會格子獨占一行;
* 如果框1設置了`float:right`,他會忽略框2和框3,直到碰到父元素;
* 如果,框1設置成`float:left`,就會覆蓋住處在普通文檔流中的框2。\(框1浮動后,框1原本在普通文檔流中的位置被框2頂替,而框1向左浮動后,由于處在普通文檔流的上層,就會蓋住框2\)。
**浮動可以內聯排列**

* 浮動會向左/向右浮動,直到碰到另一個浮動元素為止,這樣可以使區塊元素在一行顯示。
* 當三個區塊都浮動,而一行的空間不夠了,會引起元素換行。
* 但是如果每個元素的高度不一致,**會出現“卡住”的情況**。
然而,浮動也會導致一些我們不希望看見的事情發生。
**浮動會導致父元素高度坍塌**
浮動會脫離文檔流,這個問題對整個頁面布局有很大的影響。
```html
.box-wrapper { border: 5px solid red; }
.box-wrapper .box { float: left; width: 100px; height: 100px; margin: 20px; background-color: green; }
<div class="box-wrapper">
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
</div>
```
結果如下,浮動元素脫離了文檔流,并不占據文檔流的位置,自然父元素也就不能被撐開,所以沒了高度。

很明顯,這樣的效果并不符合我們的預期,所以我們需要想辦法解決這個問題。現在,我們需要清除浮動!
### 2.如何清除浮動
**清除浮動**
清除浮動的底層原理是在被清除浮動的元素上邊或者下邊添加足夠的清除空間。
要注意了,**我們是通過在別的元素上清除浮動來實現撐開高度的, 而不是在浮動元素上。**
還是接著上面的例子,我們簡單修改一下HTML代碼:
```html
<div class="box-wrapper">
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div style="clear:both;"></div>
</div>
```

哈哈,好像問題解決了!但是要注意的是,我們是在原來的頁面中添加了一個空的div元素,并且增加樣式`clear:both`,不可以在已經浮動的元素中增加清除浮動的樣式,這樣只會讓其不去進行位置浮動,但是仍然是脫離文檔流的,依然不能撐開高度。如下圖:

**清除浮動的最佳實踐**
```css
.clearfix:after {content:""; display:block; height:0; visibility:hidden; clear:both; }
.clearfix { *zoom:1; }
```
1\)`display:block`使生成的元素以塊級元素顯示,占滿剩余空間。
2\) `height:0` 避免生成內容破壞原有布局的高度。
3\) `visibility:hidden` 使生成的內容不可見,并允許可能被生成內容蓋住的內容可以進行點擊和交互。
4)通過`content:"."`生成內容作為最后一個元素,至于content里面是點還是其他都是可以的。
5)`zoom:1`觸發IE hasLayout。
通過分析發現,除了`clear:both`用來閉合浮動的,其他代碼無非都是為了隱藏掉content生成的內容。
**觸發BFC**
BFC全稱是塊狀格式化上下文,它是按照塊級盒子布局的。我們了解他的特征、觸發方式、常見使用場景這些就夠了。
**BFC的主要特征**
? BFC容器是一個隔離的容器,和其他元素互不干擾;所以我們可以用觸發兩個元素的BFC來解決垂直邊距折疊問題。
? **BFC可以包含浮動**;通常用來解決浮動父元素高度坍塌的問題。
其中,BFC清除浮動就是用的“包含浮動”這條特性。
那么,怎樣才能觸發BFC呢?
**BFC的觸發方式**
我們可以給父元素添加以下屬性來觸發BFC:
? `float` 為 `left` \| `right`
? `overflow` 為 `hidden` \| `auto` \| `scorll`
? `display` 為 `table-cell` \| `table-caption` \| `inline-block` \| `flex` \| `inline-flex`
? `position` 為 `absolute` \| `fixed`
所以我們可以給父元素設置`overflow:auto`來簡單的實現BFC清除浮動,但是為了兼容IE最好用`overflow:hidden`。但是這樣元素陰影或下拉菜單會被截斷,比較局限。所以以上的BFC觸發方法都可以用來解決浮動問題,但是要選擇合適的使用場景。
### 3.總結
有很多方法可以進行清除浮動這樣的操作,歸根到底,從原理上講其實分為兩種。
其一,通過在浮動元素的末尾添加一個空元素,設置 clear:both屬性。(after偽元素其實也是通過 content 在元素的后面生成了內容為一個點的塊級元素);
其二,使父元素觸發BFC。(通過設置父元素 overflow 或者display:table 屬性來閉合浮動)
- 前言
- 計算機軟件概論
- HTML基礎
- Web原理和HTML簡介
- Web原理
- HTML概念
- HTML標簽
- 標簽
- HTML固定基本結構
- 第一個HTML頁面
- 工具的使用
- 標題
- <hr>和<p>標簽
- 路徑概念
- 超級鏈接
- 列表
- 表格
- 表單的設計與使用
- 表單域的原理
- 文本框和密碼框
- 單選框和復選框
- 下拉列表框
- 多行文本和上傳
- 提交按鈕和重置按鈕
- 為CODING COFFEE加入在線購買頁
- HTML5
- 定位服務
- CSS
- CSS的基礎使用
- CSS簡介
- CSS樣式規則和加載方式
- 選擇器
- 偽類
- CSS優先級和層疊
- CSS顏色
- 背景圖片
- 文本
- CSS列表
- DIV+CSS布局
- 內聯元素和區塊元素介紹
- Display屬性
- 盒子模型的邊距和邊框
- 浮動和清除浮動
- 用Position屬性進行定位
- 專題:居中和對齊
- CSS新特性
- CSS3邊框
- 動畫
- JavaScript基礎
- Hello World!
- 語句和變量
- 一切皆對象
- 標識符、注釋和區塊
- 基本數據類型和引用數據類型
- 語句
- 條件語句
- 循環語句
- 數據類型
- typeof
- number
- 字符串
- 布爾類型
- 函數
- 數組
- 運算符
- 加法運算符
- 算術、賦值、比較運算符
- 布爾運算符
- DOM模型
- DOM和DOM節點
- 特征相關屬性
- 節點對象的方法
- Element對象
- Attribute對象
- Text節點和CSS操作
- 事件模型
- 標準庫
- Number對象
- String對象
- Array對象
- Date、Boolean和Math對象
- JSON對象
- 面向對象編程中的 this
- Web Storage
- 錯誤處理機制
- Error對象和try..catch語句
- javascript的原生錯誤類型
- BOM模型
- window對象
- 計時事件
- jQuery基礎
- 認識jQuery
- jQuery對象和DOM對象
- jQuery選擇器
- jQuery Dom操作
- 查找節點和創建節點
- 插入節點和刪除節點
- 復制節點和替換節點
- 包裹節點和屬性操作
- 樣式操作
- 設置和獲取HTML、文本和值
- 遍歷節點和CSS操作
- jQuery 事件和動畫
- 事件綁定與冒泡處理
- jQuery動畫
- jQuery 插件
- validate 插件
- jQuery與Ajax的應用
- Ajax簡介
- jquery中的Ajax
- Bootstrap基礎
- 起步
- 柵格系統
- 排版樣式
- 表格和按鈕
- 表單和圖片
- 輔助類和響應式工具
- 圖標菜單按鈕組件
- 輸入框和導航組件
- 路徑、分頁、標簽和徽章組件
- 巨幕、頁頭、縮略圖和警告框
- 進度、條媒體對象和Well組件
- 列表組和嵌入組件
- 數據庫
- 數據庫介紹
- MySQL的安裝
- SQL
- 表基本操作
- 修改數據語句
- 數據檢索操作
- 多表數據操作
- 表結構設計
- 綜合應用
- JAVA
- JAVA 介紹
- JAVA 運行原理
- JDK 配置
- 類和對象
- 數據類型
- 變量
- 直接量
- 運算符
- 流程控制
- 數組結構
- 面向對象
- 隱藏和封裝
- 深入構造器
- 類的繼承
- 多態
- 包裝類
- final 修飾符
- 抽象類
- 接口
- 集合框架
- 常用類學習
- 設計模式-單例模式
- 異常處理
- JDBC
- JSP&Servlet
- Web應用
- Tomcat
- JSP
- Scriptlet
- Page 指令
- 包含指令
- 跳轉指令
- 用戶注冊實例
- JSP練習
- 內置對象
- Servlet
- 過濾器
- Web分層思想
- EL表達式
- JSTL
- 分頁實現
- AJAX&JSON
- 開發步驟
- 路徑問題
- Log4j
- Java高級
- 文件操作
- 泛型
- 類加載機制和反射
- 注解 Annotation
- Mybatis框架
- 框架介紹
- Mybatis簡單實現
- 表基本操作
- 優化配置文件
- 表字段名與實體類屬性名不同的解決方案
- 一對一關聯
- 一對多關聯
- Spring框架
- Spring簡介
- IOC控制反轉
- AOP面向切面編程
- SpringMVC框架
- 教學管理
- 學員名錄
- 周測統計
- 2018-04-20
- 2018-04-27
- 2018-05-11
- 2018-05-18
- 2018-06-23
- 課堂作業
- 缺勤記錄
- 默寫記錄