欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

CSS教程:網(wǎng)頁布局定位及z-index解釋

互聯(lián)網(wǎng)   發(fā)布時間:2008-10-17 19:25:37   作者:佚名   我要評論
聲明 定位元素: position屬性值設置除默認值static以外的元素,包括relative,absolute,fixed。 平臺:win/IE win/FF z-index 用來確定定位元素在垂直于顯示屏方向(以下稱為Z軸)上的層疊順序 值:auto | 整數(shù) | inherit 默認:auto 適用于:定位元素 繼承性

一些問題的解釋
懌飛版主在《z-index在IE中的迷惑》一文中最后提到的問題:
運行代碼框

[Ctrl A 全部選擇 提示:你可先修改部分代碼,再按運行]

演示地址
http://rong179.blogbus.com/files/12163573190.html
認為:
解惑:IE瀏覽器似乎給body元素默認了一個相對定位屬性(position: relative)。

真是這樣嗎?
運行代碼框

[Ctrl A 全部選擇 提示:你可先修改部分代碼,再按運行]

演示地址
http://rong179.blogbus.com/files/12163572440.html
分析
box1顯示在body的下方,根據(jù)上面的stack level規(guī)則,IE中,如果body默認了一個位置屬性,即body是其父級stacking context,box1應顯示在其上方,事實卻不是這樣。而且當我們給body加上position:relative以后,顯示效果和stack level規(guī)則一致。所以body并沒有默認位置屬性。
那為什么負值的定位元素在IE和FF下顯示不一致呢?
ie 中根據(jù)stack level規(guī)則: z-index為負的定位元素的stack level比父級stacking context(此處是root stacking context)高,顯示在其上方。故box1在ie中能顯示。ff3.0和標準一致,也能顯示。大家可以試一下。
ff2.0 中由于那條特殊的stack level,即 z-index為負的定位元素的stack level比父級stacking context(此處是root stacking context)低,所以顯示在root stacking context下方。故不能看見。
另外,上面的代碼中加上opacity那條后,在ff2.0中即可顯示了。這又是什么原因呢?
推測:在火狐中如果給元素設置opacity屬性(1除外),即會產(chǎn)生新的stacking context。
上面加上opacity屬性后在ff2.0中可顯示box1在body下,ff3.0box1在body上,(可以根據(jù)上面的stack level規(guī)則自己分析)符合推測。
在w3c的說明中也證明這點

In future levels of CSS, other properties may
introduce stacking contexts, for example 'opacity'
[CSS3COLOR].

總結(jié)
在一個stacking context中元素的z-軸顯示順序,由元素所處的 stack level 決定。對于同一stack level的定位元素由z-index的大小進一步?jīng)Q定顯示次序。 ie中給元素設置position屬性(static除外)可產(chǎn)生新的stacking context ff中給元素設置opacity屬性(1除外)可產(chǎn)生新的stacking context
除此之外(也許設置其他屬性也會產(chǎn)生新的stacking context,但還不知道)只有定位元素設置了z-index(auto除外)才會產(chǎn)生新的stacking context,子元素將按照新的stacking context,定位。

在FF3.0中結(jié)果和標準順序一致。FF2.0中“z-index值為負值的定位元素”在父級stacking context的背景下面。(注意ff2.0的這個特殊性)
IE下測試
運行代碼框

[Ctrl A 全部選擇 提示:你可先修改部分代碼,再按運行]

測試頁面
http://rong179.blogbus.com/files/12163574751.html(請在IE下瀏覽)
代碼說明
此代碼也是根據(jù)上面的測試思想,但由于inline元素在ie中的特殊性,把inline的代碼寫在了后面,事實證明結(jié)論是正確的。對于“block元素”和“float元素”順序大家可以交換順序測試。
測試結(jié)論
IE下(無論ie6.0或者ie7.0)“float元素”和“block元素”屬同一stack level,而“inline元素”較其stack level低。
解釋
“float元素”,“z-index:auto的定位元素”仿佛產(chǎn)生了新的stacking context,但其真正能產(chǎn)生新的stacking context的后代任按其父級stacking context定位。(但IE中“z-index:auto的定位元素”
會擁有z-index值0,產(chǎn)生一個新的stacking context,并影響其子元素定位。這是IE一個BUG)
inline元素在FF中仿佛能產(chǎn)生新的stacking context,而在IE中則不能。

至此stack level規(guī)則內(nèi)容已經(jīng)完畢,現(xiàn)在應該能理解stack level和z-index的不同。stack level來決定這一個stacking context中各元素在z軸上的顯示順序,對于同一stack level的定位元素才由z-index進一步?jīng)Q定顯示次序。

相關文章

  • css z-index 最大值

    z-index最大值,最小值以及同值時層的高低,做了個測試z-index的最大值,有幾個結(jié)論如下
    2009-05-28
  • css z-index 在IE中的迷惑

    z-index屬性簡介 引用: z-index : auto | number auto:默認值。 number:無單位的整數(shù)值,可為負數(shù)。 z-index 值較大的元素將疊加在z-index值較小的元素之上。對
    2009-05-29
  • CSS教程:元素層疊級別及z-index-CSS教程-網(wǎng)頁制作-網(wǎng)頁教學網(wǎng)

    原文:http://rong179.blogbus.com/logs/24966909.html 聲明 定位元素:position屬性值設置除默認值static以外的元素,包括relative,absolute,fixed。 平臺:win/I
    2008-10-17
  • css設置z-index 失效的解決方法

    設置z-index時必須要固定位置,這樣設置它的值時才能奏效(例如 position:absolute;)下面是示例代碼,在ff3.5.5和ie5.5~ie8.0RC1中通過,大家可以嘗試著不固定其位置試試
    2009-11-26
  • CSS 定位之 z-index 問題分析

    IE6/7對z-index的表現(xiàn)跟IE8及以上瀏覽器不一致。position值為非static時,如果不設置z-index屬性,IE6/7下z-index默認為0,而IE8及以上瀏覽器z-index為auto,且zindex:auto
    2012-11-13
  • 一個關于CSS Z-index 的東東,解決了我很多疑問

    發(fā)現(xiàn)有時候真得多看看書,以前一直納悶為什么有時候可以,有時候不可以,原來是這個原因.
    2011-03-23
  • CSS的z-index實例代碼

    寫了個最簡單的DEMO,演示了3個DIV互相遮蓋的情況。記住:z-index要配合position屬性才有效
    2012-02-25
  • ie下的css層疊z-index各種問題詳細整理

    可是真有些日子沒有寫DIV+CSS了,而且對IE6兼容性的坑碰到的還是不夠多(以前做國外項目),所以這次開發(fā)中不可避免的碰見了幾個問題,尤其是在IE下的 z-index 問題很有意思
    2013-01-09
  • CSS元素的層疊與z-index設置-CSS教程-網(wǎng)頁制作-網(wǎng)頁教學網(wǎng)

      我們在文章的更新中,特別注重對新手的輔導,但webjx.com面對的是廣大的開發(fā)人員,大家可能會遇到各種各樣的問題,有些問題很不常見,或者應用的很少,但我們依然有必
    2008-10-17
  • CSS屬性探秘系列(七):z-index

    在這篇文章里,我們會準確的說明究竟什么是Z-index,它為什么會這么不為人所了解,并一起討論一些關于它的實際使用中的問題。我們同時會描述一些會遇到的瀏覽器間的差異,
    2014-10-22

最新評論