成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

CSS布局中閉合浮動元素方法揭秘

開發 前端
本文向大家描述一下CSS布局中閉合浮動元素的方法,按照CSS規范,浮動元素(floats)會被移出文檔流,不會影響到塊狀盒子的布局而只會影響內聯盒子(通常是文本)的排列。

你對CSS中閉合浮動元素的方法是否熟悉,這里和大家分享一下,按照CSS規范,浮動元素(floats)會被移出文檔流,不會影響到塊狀盒子的布局而只會影響內聯盒子(通常是文本)的排列。因此當其高度超出包含容器時,一般父容器不會自動伸長以閉合浮動元素。

Div+CSS教程:如何閉合浮動元素?

  按照CSS規范,浮動元素(floats)會被移出文檔流,不會影響到塊狀盒子的布局而只會影響內聯盒子(通常是文本)的排列。因此當其高度超出包含容器時,一般父容器不會自動伸長以閉合浮動元素。但是有時我們卻需要這種自動閉合行為,具體如何處理呢?

***種:

在父容器內再插入一個額外的標簽,并令其清除浮動(clear)以撐大父容器。這種方法瀏覽器兼容性好,沒有什么問題,缺點就是需要額外的(而且通常是無語義的)標簽,所以我個人不大喜歡。

第二種:

使用:after偽類動態的嵌入一個用于清除浮動的元素,這種方法和上一種原理一樣,不同的只是把這個額外的內容用CSS生成,但考慮到IE不支持:after不得不做了不少的hack。這種方法兼容性一般,但經過各種hack也可以應付不同瀏覽器了,同時又可以保證html比較干凈,所以用得還是比較多的。

第三種:

將父容器的overflow設為除visible之外的值就可以在標準兼容瀏覽器中閉合浮動元素,IE自然又是不支持的,所以這種方法和上一種方法一樣都對IE做了不同處理(具體就是觸發layout),不同的就是overflow沒有:after偽類那么麻煩了,缺點也有,overflow可能會產生一些小沖突。

  在使用overflow之前還有過一種使用float的方法,就是讓父容器也浮動,這利用到了浮動元素的一個特性——浮動元素會閉合浮動元素。這種方式在IE/Win和標準兼容瀏覽器中都有較好的效果,但缺點也很明顯——父容器未必想浮動就浮動的了,畢竟浮動是一種比較特殊的行為,有時布局不允許其浮動也很正常。使用float雖然在IE和標準兼容瀏覽器中都能閉合浮動元素,但原理卻是不同的,IE/Win中float觸發了layout因而閉合了浮動,而在標準兼容瀏覽器中,float其實和上一種方法中的overflow原理一樣,產生了一個“塊級格式化范圍”——這是CSS規范中提到的一種現象,它往往具有某種獨立性,特性之一就是會自動閉合內部的浮動元素。

  按照規范,以下類型的元素會產生一個塊級格式化范圍:

  ◆浮動元素,left或者right皆可。

  ◆絕對定位的元素。

  ◆inline-block元素,不過這個gecko目前不支持。

  ◆table-cell類型元素,其實table,table-head-group,table-row什么的也都可以,還有inline-table(gecko不支持)也同樣,因為他們都會間接產生一個匿名的table-cell。

  ◆overflow取值非visible的元素。

  所以,原來在標準兼容瀏覽器中我們也可以有這么多的方法閉合一個浮動元素,而且只需要CSS,無需其他。順帶說一下以上除了overflow,其余都有一個附加效果就是自動收縮父容器寬度。

  而對于IE/Win,它有一套自己的體系,就是layout,具有layout的元素會自動閉合浮動元素,再來看看觸發layout的CSS屬性,會發現和上面的塊級格式化范圍有很多類似之處:

  ◆浮動元素

  ◆絕對定位元素

  ◆display:inline-block

  ◆zoom

  ◆width/height

  ◆overflow/overflowx/overflow-y[IE7新增]

  ◆max/min-width/height[IE7新增]

  以上來看IE中閉合浮動元素的方法也不少,自然也都有其局限性,要么有附帶效果,要么使用的是非標準屬性(無法通過驗證)。

  還要提一點的是display:inline-block,這個屬性對IE而言本身沒什么用,實際效果只是給一個元素暗地添加了layout,但是標準兼容瀏覽器是認得這個屬性的,所以要不影響這些瀏覽器,需要將display設回默認。這里IE有一個bug,如果先定義了display:inline-block,然后再將display設回block(這兩個display要先后放在兩個CSS聲明中才有效果),那么layout不會消失,同時也不會影響其他瀏覽器,所以目前來說,這也算一個不錯的觸發layout的方法:

ExampleSourceCode

  1. .gainlayout{display:inline-block;}  
  2.  
  3. .gainlayout{display:block;}  
  4.  

  所以要跨瀏覽器閉合浮動元素,可以選擇的方式還是很多的,如何搭配使用這些CSS屬性就要具體情況具體分析了,靈活應用條件注釋也很有必要,要是實在不行我們回過頭來還有clear可以用嘛。
 

【編輯推薦】

  1. CSS Sprites對CSS布局的意義
  2. CSS布局中float和position屬性使用技巧
  3. 專家提醒 CSS編碼時易范十大錯誤
  4. CSS Sprites對CSS布局的意義及優缺點
  5. CSS布局中display:inline-block屬性用法詳解

 

 

責任編輯:佚名 來源: 52css.com
相關推薦

2010-09-13 09:54:56

CSS浮動元素

2010-09-01 12:50:04

CSS清除浮動

2023-05-15 08:34:36

css浮動

2010-09-14 17:07:26

DIV浮動定位CSS

2010-09-01 14:02:27

絕對定位浮動CSS

2010-08-16 14:18:49

DIV+CSS

2010-09-06 15:46:08

CSSDIV

2010-09-07 15:38:42

CSS絕對定位浮動

2010-08-23 15:22:56

CSSfloat

2010-09-03 13:23:07

absoluterelativeCSS

2010-09-14 14:42:24

FlashDIV CSS

2010-09-13 12:56:56

CSSpositionfloat

2010-09-14 09:24:40

CSS實例

2010-09-02 13:03:38

CSS垂直居中

2010-08-23 10:43:21

DIVCSS

2010-08-31 15:07:45

CSS居中

2017-02-06 09:40:35

浮動布局 浮動

2023-06-29 15:10:48

Web開發CSS

2010-08-24 13:34:11

CSSpadding

2013-03-28 11:02:26

CSS浮動
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品一区二区在线播放 | 日韩黄a | 国产伦一区二区三区久久 | 色偷偷噜噜噜亚洲男人 | 性欧美hd | 男女视频在线观看网站 | 99re视频在线观看 | 日韩中文字幕一区二区 | 久久不卡| 蜜桃传媒av | 欧美精品一区三区 | 国产精品一区二区久久久久 | 日本精品在线观看 | 成人国产免费视频 | 国产一区二区三区四区五区加勒比 | 日韩中文在线 | 日韩精品一区二区三区老鸭窝 | 中文视频在线 | avhd101在线成人播放 | 精品国偷自产在线 | 日韩视频1| 国产精品久久av | 国产一区二区不卡 | 久久综合久久综合久久 | 国产精品久久久久一区二区 | 精国产品一区二区三区四季综 | 久久精品国产一区老色匹 | 国内精品一区二区三区 | 久久高清国产视频 | 青青草网站在线观看 | 国产美女在线看 | 欧美日韩国产一区二区三区 | 中文字幕av在线一二三区 | 亚洲国产高清高潮精品美女 | 亚洲三区在线 | 欧美精品一区二区三区在线 | 国产精品亚洲视频 | 久久99精品国产麻豆婷婷 | 91看片网 | 国产观看 | 中文字幕一区二区三区精彩视频 |