CSS清除浮動常用方法小結

來源:互聯網
上載者:User

常用的清除浮動的方法有以下三種。
此為未清除浮動原始碼,運行代碼無法查看到父級元素淺黃色背景。

<br /><style type="text/css"> <!-- *{margin:0;padding:0;} body{font:36px bold; color:#F00; text-align:center;} #layout{background:#FF9;} #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;} #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;} --> </style>LeftRight<p>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

1、使用空標籤清除浮動。我用了很久的一種方法,空標籤可以是div標籤,也可以是P標籤。我習慣用<P>,夠簡短,也有很多人用<hr>,只是需要另外為其清除邊框,但理論上可以是任何標籤。這種方式是在需要清除浮動的父級元素內部的所有浮動元素後添加這樣一個標籤清楚浮動,並為其定義CSS代碼:clear:both。此方法的弊端在於增加了無意義的結構元素。

<br /><style type="text/css"> <!-- *{margin:0;padding:0;} body{font:36px bold; color:#F00; text-align:center;} #layout{background:#FF9;} #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;} #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;} .clr{clear:both;} --> </style>LeftRight<p class="clr"><p>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

2、使用overflow屬性。此方法有效地解決了通過空標籤元素清除浮動而不得不增加無意代碼的弊端。使用該方法是只需在需要清除浮動的元素中定義CSS屬性:overflow:auto,即可!"zoom:1"用於相容IE6。 <br /><style type="text/css"> <!-- *{margin:0;padding:0;} body{font:36px bold; color:#F00; text-align:center;} #layout{background:#FF9;overflow:auto;zoom:1;} #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;} #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;} --> </style>LeftRight<p>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

3、使用after偽對象清楚浮動。該方法只適用於非IE瀏覽器。具體寫法可參照以下樣本。使用中需注意以下幾點。一、該方法中必須為需要清除浮動元素的偽對象中設定height:0,否則該元素會比實際高出若干像素;二、content屬性是必須的,但其值可以為空白,藍色理想討論該方法的時候content屬性的值設為".",但我發現為空白亦是可以的。

<br /><style type="text/css"> <!-- *{margin:0;padding:0;} body{font:36px bold; color:#F00; text-align:center;} #layout{background:#FF9;} #layout:after{display:block;clear:both;content:"";visibility:hidden;height:0;} #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;} #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;} --> </style>LeftRight<p>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

此三種方法皆有一定弊端,使用時應擇優選擇,比較之下第二種方法更為可取。以上方法,並非原創,皆來源於網路,在此小作整理,原作者著作權所有,並保留一切權利。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.