CSS那些事兒-閱讀隨筆3(清除浮動)

来源:http://www.cnblogs.com/flyrui316/archive/2016/01/29/5168422.html
-Advertisement-
Play Games

介紹了幾種清除浮動的方法


  浮動主要是由浮動(float)屬性導致的頁面錯位現象,清除浮動不僅能解決頁面錯位的現象,還可以解決子元素浮動導致父元素背景無法自適應子元素高度的問題。在CSS樣式中,主要利用clear屬性中的both、left和right 3個屬性值清除由浮動產生的左、右浮動效果。

一、浮動現象例子

下麵舉一個很簡單的浮動的例子,假設一個float_box(背景色為#aff)中包含兩個div,且一個是左浮動(float:left),另一個是右浮動(float:right)。在float_box外再添加一個沒有浮動屬性的div(no_float),那麼代碼以及預期效果和實際效果如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css-test</title>
 6     <style>
 7         .float_box{
 8             background-color: #aff;
 9         }
10         .float_left{
11             float:left;
12             width: 200px;
13             height: 100px;
14             border: 2px solid #f00;
15         }
16         .float_right{
17             float:right;
18             width: 200px;
19             height: 100px;
20             border: 2px solid #00f;
21         }
22         .no_float{
23             color: #fff;
24             background-color: #aaa;
25         }
26     </style>
27 </head>
28 <body>
29 <div class="float_box">
30     <div class="float_left">左浮動元素</div>
31     <div class="float_right">右浮動元素</div>
32 </div>
33 <div class="no_float">測試位置</div>
34 
35 </body>
36 </html>
View Code

      

                                     a.預期效果                                                                                 b.實際效果

                              圖1 效果圖

二、消除浮動的方法

1.利用br元素的clear屬性

  br標簽屬性中的clear屬性具有left、right和all三個屬性值,可以用來清除浮動。但是此種方法需要引入一個額外的br標簽,破壞了HTML的原有結構。代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css-test</title>
 6     <style>
 7         .float_box{
 8             background-color: #aff;
 9             /*zoom: 1;*/
10             /*overflow: hidden;*/
11         }
12         .float_left{
13             float:left;
14             width: 200px;
15             height: 100px;
16             border: 2px solid #f00;
17         }
18         .float_right{
19             float:right;
20             width: 200px;
21             height: 100px;
22             border: 2px solid #00f;
23         }
24         .no_float{
25             color: #fff;
26             background-color: #aaa;
27             /*clear: both;*/
28         }
29     </style>
30 </head>
31 <body>
32 <div class="float_box">
33     <div class="float_left">左浮動元素</div>
34     <div class="float_right">右浮動元素</div>
35     <br clear="all">
36 </div>
37 <div class="no_float">測試位置</div>
38 </body>
39 </html>
View Code

效果如圖1(a)所示。

2.利用css樣式中的clear屬性

  a.引入br標簽,但是為其添加css修飾.clear_float{clear:both;},代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css-test</title>
 6     <style>
 7         .float_box{
 8             background-color: #aff;
 9             /*zoom: 1;*/
10             /*overflow: hidden;*/
11         }
12         .float_left{
13             float:left;
14             width: 200px;
15             height: 100px;
16             border: 2px solid #f00;
17         }
18         .float_right{
19             float:right;
20             width: 200px;
21             height: 100px;
22             border: 2px solid #00f;
23         }
24         .no_float{
25             color: #fff;
26             background-color: #aaa;
27             /*clear: both;*/
28         }
29         .clear_float{
30             clear: both;
31         }
32     </style>
33 </head>
34 <body>
35 <div class="float_box">
36     <div class="float_left">左浮動元素</div>
37     <div class="float_right">右浮動元素</div>
38     <br class="clear_float">
39 </div>
40 <div class="no_float">測試位置</div>
41 </body>
42 </html>
View Code

效果如圖1(a)所示。

  b.在發生浮動的元素後的元素中添加.clear_float{clear:both;},避免引入多餘的HTML元素,代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css-test</title>
 6     <style>
 7         .float_box{
 8             background-color: #aff;
 9             /*zoom: 1;*/
10             /*overflow: hidden;*/
11         }
12         .float_left{
13             float:left;
14             width: 200px;
15             height: 100px;
16             border: 2px solid #f00;
17         }
18         .float_right{
19             float:right;
20             width: 200px;
21             height: 100px;
22             border: 2px solid #00f;
23         }
24         .no_float{
25             color: #fff;
26             background-color: #aaa;
27             /*clear: both;*/
28         }
29         .clear_float{
30             clear: both;
31         }
32     </style>
33 </head>
34 <body>
35 <div class="float_box">
36     <div class="float_left">左浮動元素</div>
37     <div class="float_right">右浮動元素</div>
38 </div>
39 <div class="no_float clear_float">測試位置</div>
40 </body>
41 </html>
View Code

效果如下圖:

  可以從上圖中看出,雖然這種方法清除了浮動的錯誤,但是float元素的父元素高度沒有適應float元素的高度(背景沒顏色)。

3.利用css中的overflow屬性

  為float元素的父元素添加css屬性overflow:hidden,也可以清除浮動且高度適應。但是該屬性會使div溢出部分隱藏,存在弊端。代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css-test</title>
 6     <style>
 7         .float_box{
 8             background-color: #aff;
 9             overflow: hidden;
10         }
11         .float_left{
12             float:left;
13             width: 200px;
14             height: 100px;
15             border: 2px solid #f00;
16         }
17         .float_right{
18             float:right;
19             width: 200px;
20             height: 100px;
21             border: 2px solid #00f;
22         }
23         .no_float{
24             color: #fff;
25             background-color: #aaa;
26         }
27     </style>
28 </head>
29 <body>
30 <div class="float_box">
31     <div class="float_left">左浮動元素</div>
32     <div class="float_right">右浮動元素</div>
33 </div>
34 <div class="no_float">測試位置</div>
35 </body>
36 </html>
View Code

效果如圖1(a)所示。

註:overflow:visible清除浮動只對ie瀏覽器有效,overflow:auto清除浮動且多層嵌套時,會對點擊事件產生影響。

4.利用css中的display:table屬性

  為float元素的父元素添加css屬性display:table,也可以清除浮動且高度適應。但是會引起意想不到的後果。代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css-test</title>
 6     <style>
 7         .float_box{
 8             background-color: #aff;
 9             display:table;
10         }
11         .float_left{
12             float:left;
13             width: 200px;
14             height: 100px;
15             border: 2px solid #f00;
16         }
17         .float_right{
18             float:right;
19             width: 200px;
20             height: 100px;
21             border: 2px solid #00f;
22         }
23         .no_float{
24             color: #fff;
25             background-color: #aaa;
26         }
27     </style>
28 </head>
29 <body>
30 <div class="float_box">
31     <div class="float_left">左浮動元素</div>
32     <div class="float_right">右浮動元素</div>
33 </div>
34 <div class="no_float">測試位置</div>
35 </body>
36 </html>
View Code

效果如下圖所示:

5.利用css偽對象::after

  清除浮動的條件之一是必須在浮動元素之後,因此只能利用::after而不使用::before (對於ie瀏覽器,需要9或以上才支持),代碼如下:

 1 <!DOCTYPE html>
 2 <html 	   

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • css實現評分效果,其實是css sprit (css精靈)的延伸應用,效果的實現主要是由 background-position 屬性移
  • JavaScript模擬右鍵菜單
  • 本文前面部分轉自木-葉的博文,後面有本人自己的一些總結和體會。 如果有人問你,GET和POST,有什麼區別?你會如何回答? 我的經歷 前幾天有人問我這個問題。我說GET是用於獲取數據的,POST,一般用於將數據發給伺服器之用。 這個答案好像並不是他想要的。於是他繼續追問有沒有別的區別?我說這就是個名
  • 1任何對象都有__proto__屬性 屬性值Object2並不是所有對象都有prototype屬性。只有方法對象(構造函數)以及基本數據類型還有Array,有prototype屬性;並且所有方法(對象)的prototype屬性都是object 在網上有很多關於原型的講解。在這裡我用console.l
  • 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.
  • a.nodejs安裝 nodejs的安裝沒有什麼說的預設安裝即可。安裝包官網下載即可:nodejs官網 本人用的是window的安裝包node-v4.2.6-x64.msi 安裝完成後打開命令行查看使用node -v命令查看安裝node版本,有版本號展示說明安裝成功啦 需要創建一個文件夾作為node
  • 給人做H5頁面時候,在下麵添加了微信二維碼,在安卓機中通過微信打開並長按圖片後能正常識別出來, 但是在蘋果系統就怎麼按都沒用,二維碼不能識別。 一行行代碼排查,也看過很多資料感覺還是識別時候,計算圖片高度有偏差,這可能和解析CSS樣式有關,無法正確計算出圖片在屏幕中的高度而導致識別時候有問題。 調整
  • 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...