国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

CSS清理浮動方式更簡潔的方案

2024-07-11 09:02:23
字體:
來源:轉載
供稿:網友

武林網(m.survivalescaperooms.com)文章簡介:清理浮動有很多種方式,像使用 br 標簽自帶的 clear 屬,使用元素的 overflow,使用空標簽來設置 clear:both 等等。但考慮到兼容問題和語義化的問題,一般我們都會使用如下代碼來清理浮動。

清理浮動有很多種方式,像使用 br 標簽自帶的 clear 屬,使用元素的 overflow,使用空標簽來設置 clear:both 等等。但考慮到兼容問題和語義化的問題,一般我們都會使用如下代碼來清理浮動。

/* 清理浮動 */
 .clearfix:after {
 visibility:hidden;
 display:block;
 font-size:0;
 content:" ";
 clear:both;
 height:0;
 }
 .clearfix {
 zoom:1;
 }
 

其原理是,在「高級」瀏覽器中使用 :after 偽類在浮動塊后面加上一個非 display:none 的不可見塊狀內容來,并給它設置 clear:both 來清理浮動。在 ie6 和 7 中給浮動塊添加 haslayout 來讓浮動塊撐高并正常影響文檔流。

上面的代碼應該是現在主流的清理浮動方式。現在支付寶就使用這樣的方式。而現在,Nicolas Gallagher 給出了一個更簡潔的方案:

.cf:before, .cf:after {
     content:"";
     display:table;
 }
 .cf:after {
     clear:both;
 }
 .cf {
     zoom:1;
 }

原理還是一樣的。使用 :after 偽類來提供浮動塊后的 clear:both。不同的是,隱藏這個空白使用的是 display: table。而不是設置 visibility:hidden;height:0;font-size:0; 這樣的 hack。

值得注意的是這里中的 :before 偽類。其實他是來用處理 top-margin 邊折疊的,跟清理浮動沒有多大的關系。但因為浮動會創建 block formatting context,這樣浮動元素上的另而一元素上如果剛好有 margin-bottom 而這個浮動元素剛好有margin-top 的話,應該讓他們不折疊(雖然這種情況并不常見)。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿巴嘎旗| 平安县| 广丰县| 台安县| 公安县| 西乌| 班玛县| 嘉定区| 霸州市| 沙坪坝区| 湛江市| 称多县| 都匀市| 清原| 常州市| 博野县| 九寨沟县| 嘉鱼县| 南昌市| 普洱| 星子县| 普宁市| 安平县| 肃宁县| 壶关县| 乾安县| 孝昌县| 信宜市| 三亚市| 靖边县| 阿拉善右旗| 台东县| 乐平市| 辽中县| 元谋县| 昌图县| 漳浦县| 北流市| 华宁县| 白玉县| 广宗县|