国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

bug記錄:IE8,包含塊min-height/height共存時的高度計算bug

suxier / 2374人閱讀

摘要:的是,被的覆蓋,最終的高度值為計算值。這里所有的瀏覽器都計算正確。

本文源自對http://segmentfault.com/q/1010000000378457的探索

問題條件

問題的條件有:

A元素是B元素的包含塊。

A元素設置overflow:hidden;,并同時設置了heightmin-height,同時height計算值 < min-height

原生IE8瀏覽器,或者IE9瀏覽器的IE8兼容性模式(以下統稱為IE8)

期待結果:

若B元素為absolute定位元素,A元素為relative定位元素,則B元素的包含塊高度為A元素的padding-edge高度

若A、B元素均為常規流定位元素,則B元素的包含塊高度為A元素的content-box高度

若A元素同時設置了min-heightheight,同時height計算值小于min-height。因為height權重小于min-height,最終A元素的content-box高度計算值應以min-height為準

IE8的bug是:

若B元素的包含塊的content-box的值計算錯誤,在height計算值小于min-height的同時,誤取了heihgt值作為其包含塊的content-box部分

B元素跟其包含塊有關的屬性,如百分比top/bottom/百分比height均受到影響,因此,B元素的位置可能受到影響

A元素的最終高度計算依然正確

受到影響的僅僅是以A元素為包含塊的元素,包括B元素

DEMO

一個使用了absolute定位的DEMO:

http://jsfiddle.net/humphry/Xzy28/7/

一個未使用absolute定位的DEMO,可見jsfiddle:

http://jsfiddle.net/humphry/NSCLa/8/

我們看一下渲染結果的區別。

計算流程,試解釋
absolute static
其他瀏覽器 外層高500/內層高500 外層高500/內層高300
IE8 外層高500/內層高220 外層高500/內層高20

我們先看看外層的計算。

.wrapperheight是20px,被min-height的300px覆蓋,最終的高度值為:100px padding-top + 100px padding-bottom + 200px height計算值 = 500px。這里所有的瀏覽器都計算正確。

對于內層,IE8/其他正常瀏覽器,在absolute定位和static定位下的區別有:

正常瀏覽器,.innerabsolute定位: .inner設置了100%高度,即100%的包含塊的高度,即外層容器的padding-edge高度,也就是外層容器的 200px padding高度 + 300px content-box高度 = 500px

IE8瀏覽器,.innerabsolute定位: .inner的包含塊的content-box高度誤用了height值而非min-height值,計算出來高度值為 200px padding高度 + 20px height高度 = 220px

正常瀏覽器,.inner static定位: .inner設置了100%高度,即100%的包含塊的高度,即外層容器的content-box高度,也就是外層容器的 300px content-box高度 = 300px

IE8瀏覽器,.inner static定位: .inner的包含塊的content-box高度誤用了height值而非min-height值,計算出來高度值為 20px height高度 = 20px

解決方案

去掉.wrapper上的overflow:hidden;

overflow:hidden;加在不【同時設置heightmin-height,且height計算值<min-height】的元素上

參考資料

關于包含塊的判定:http://w3help.org/zh-cn/kb/008/

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/110849.html

相關文章

  • 談談BFC與ie特有屬性hasLayout

    摘要:當一個內聯元素想獲得就要使用這個屬性。下因為導致的浮動元素與普通元素之間產生代碼如下我是浮動元素我是后面的文字,用來測試的正常情況下解決方式加一個的不只是文字,的浮動元素也會和內聯元素產生的值。設置屬性的元素不和任何元素發生合并。 發現我好久沒更新博文了=-=這里把我之前在博客園寫過的一篇關于BFC的文章粘貼過來,順便自己也再次做個總結。 最近看了一篇總結ie常見bug的文章,里面提...

    CodeSheep 評論0 收藏0
  • 談談BFC與ie特有屬性hasLayout

    摘要:當一個內聯元素想獲得就要使用這個屬性。下因為導致的浮動元素與普通元素之間產生代碼如下我是浮動元素我是后面的文字,用來測試的正常情況下解決方式加一個的不只是文字,的浮動元素也會和內聯元素產生的值。設置屬性的元素不和任何元素發生合并。 發現我好久沒更新博文了=-=這里把我之前在博客園寫過的一篇關于BFC的文章粘貼過來,順便自己也再次做個總結。 最近看了一篇總結ie常見bug的文章,里面提...

    iliyaku 評論0 收藏0
  • 整理:子容器垂直居中于父容器的方案

    摘要:子容器溢出時,父容器出現滾動條。父容器或很顯然,子容器溢出時,被父容器截斷的情形無法和父容器自適應于子容器共存。現在這個布局可以自動生成,詳見林小志的小工具圖片垂直居中。溢出子容器溢出時會變成頂對齊,原因同上。 本文在evernote里有備份。如果evernote的閱讀區域嫌窄了,那么可以把這個鏈接拖入書簽并點擊javascript:jQuery(#container).width(9...

    youkede 評論0 收藏0
  • 屬性設置百分比時的計算參考匯總

    摘要:對象脫離常規流,偏移定位是以窗口為參考絕對定位的元素,在,,,屬性未設置時,會緊隨在其前面的兄弟元素之后,但在位置上不影響常規流中的任何元素。例如設置百分比時,子元素繼承是父元素乘以百分百之后的具體數值,所以可能會出現重疊現象。元素寬高 width,min-width,max-width等元素寬度設置百分比,以包含塊的寬度為標準進行計算; height,min-height,max-hei...

    Moxmi 評論0 收藏0
  • CSS概念【記錄

    摘要:語法規則注釋層疊優先級繼承值塊格式化上下文盒模型層疊上下文可替換元素外邊距合并包含塊視覺格式化模型布局模式語法屬性值聲明聲明塊規則規則集規則規則一個語句定義樣式表使用的字符集告訴引擎引入一個外部樣式表嵌套規則如果滿足媒介查詢的條件則條件規則 1、CSS語法 2、@規則 3、注釋 4、層疊 5、優先級 6、繼承 7、值 8、塊格式化上下文 9、盒模型 10、層疊上下文 11、可替換元素 12、...

    番茄西紅柿 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<