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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...