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

資訊專欄INFORMATION COLUMN

CSS魔法堂:你真的理解z-index嗎?

andycall / 1973人閱讀

摘要:與的映射關(guān)系為。與根對應(yīng)的對應(yīng)的層疊上下文,是其他的祖先,的范圍覆蓋整條。注意的默認(rèn)值為,自動賦值為。對于,它會將賦予給對應(yīng)的,而則不會。

一、前言                              

?假如只是開發(fā)簡單的彈窗效果,懂得通過z-index來調(diào)整元素間的層疊關(guān)系就夠了。但要將多個彈窗間層疊關(guān)系給處理好,那么充分理解z-index背后的原理及兼容性問題就是必要的知識儲備了。本文作為對W3C Recommendation-Layered presentation學(xué)習(xí)后整理的筆記,以便日后查閱。
?由于將英文名詞翻譯為中文名詞容易產(chǎn)生歧義(如Normal flow被翻譯為文檔流),因此本文將直接采用原英文名詞,而涉及到的英文名詞解釋如下:
?non-positioned element:無CSS定位的元素,也就是position: static的元素。
?positioned element:CSS定位的元素,也就是position: relative/absolute/fixed的元素。
?box:文檔樹由element組成,渲染樹由box組成,實際進行元素大小、布局渲染操作的對象是box進行而不是element。box由element對應(yīng)生成(也有是anonymous box不是由element對應(yīng)生成,而是渲染器根據(jù)規(guī)則自動生成),non-positioned element對應(yīng)的是non-position box,positioned element對應(yīng)的是position box。
?z-axis:box定位坐標(biāo)系中的z軸。
?stacking context:層疊上下文,z-axis的基本組成單位。box與stacking context的映射關(guān)系為N:1。每個stacking context有一個父context(除了root stacking context外)和0~N個子context。
?root stacking context:與根box(html/body對應(yīng)的box)對應(yīng)的層疊上下文,是其他stacking context的祖先context,root stacking context的范圍覆蓋整條z-axis。
?stack level:層疊等級,當(dāng)N個box位于同一個stacking context中,則通過stack level來決定它們位于z-axis上的位置。注意:stack level為相對值而非如px那樣為絕對值。

二、圖解分層顯示

?其實我們常接觸到的z-index只是分層顯示中的一個屬性而已,而理解z-index背后的原理實質(zhì)上就是要理解分層顯示原理。下面我們通過一個示例來認(rèn)識一下分層顯示涉及的對象和屬性(z-axis、(root) stacking context、box、stack level)以及它們之間的關(guān)系。
HTML Markup



  


說明:

在構(gòu)造渲染樹時會為element生成對應(yīng)的box,所以div#d1->d1:box,div#d2->d2:box,div#d3->d3:box,div#d4->d4:box,p#p1->p1:box。

對于positioned box而言,若z-index屬性值不是0,則會創(chuàng)建一個新的stacking context,并且其子孫box將屬于這個新stacking context。

同一個stacking context的z-index才具有可比性,也就是說在討論z-index時必須帶說明是哪個stacking context下的z-index。如示例般,雖然-9999比10小,但由于d4:box和d1:box位于不同的stacking context,因此無法判斷哪個box更靠近用戶。

三、層疊規(guī)則                          

?層疊規(guī)則就是決定到底哪個box更靠近用戶。

前提:boxes屬于同一個stacking context,并且z-index相同

   規(guī)則:按照box對應(yīng)的element在文檔樹的順序,后者比前者更靠近用戶(back-to-front)

前提:boxes屬于同一個stacking context,并且z-index不同

    規(guī)則:z-index屬性值大的box更靠近用戶

前提:boxes屬于不同的stacking context,并且stacking contexts沒有祖孫/父子關(guān)系

    規(guī)則:boxes會向上沿著父box進行搜索,直到父boxes屬于同一個stacking context為止,然后比較父boxes的z-index屬性值,z-index屬性值大的box更靠近用戶。
d3
d2
d3

前提:boxes屬于不同的stacking context,并且stacking contexts為祖孫/父子關(guān)系

    規(guī)則:屬于子stacking context的box必定更靠近用戶

前提:boxes屬于相同的stacking context,并且兩者都是non-positioned element。

    規(guī)則:float:left|right的元素必定更靠近用戶

四、z-index的作用                        

?啰嗦一句:同一個stacking context的z-index才具有可比性,也就是說在討論z-index時必須帶說明是哪個stacking context下的z-index。
?它有兩個作用:

設(shè)置box在其所屬的stacking context下的stack level;

當(dāng)z-index屬性值非0時,則在該box中創(chuàng)建一個新的stacking context,而該box的子孫box默認(rèn)屬于這個新stacking context。

?注意:z-index的默認(rèn)值為auto,自動賦值為0。因此默認(rèn)情況下不會創(chuàng)建新的stacking context。

z-index生效的閥門

?z-index屬性值僅對positioned box生效,而non-positioned box的z-index永遠(yuǎn)為0。
?也許你會舉出如下反例:

?但抱歉的是,上面獲取的是non-positioned element div#d1的z-index屬性值,而不是non-positioned box的z-index屬性值。
?對于positioned element,它會將z-index賦予給對應(yīng)的positioned box,而non-positioned element則不會。

五、兼容性問題——IE6/7的詭異行為                

?IE6、7中并非當(dāng)positioned box并且z-index不為0時才創(chuàng)建stacking context,而是positioned box就會創(chuàng)建stacking context。


 
20
10
2
1

?符合W3C標(biāo)準(zhǔn)的渲染效果:

?IE6、7下的渲染效果:

六、總結(jié)                            

?若有紕漏請大家指正,謝謝!
?尊重原創(chuàng),轉(zhuǎn)載請注明來自:http://www.cnblogs.com/fsjohnhuang/p/4333164.html ^_^肥仔John

七、參考                            

《說說標(biāo)準(zhǔn)——CSS核心可視化格式模型(visual formatting model)之十三:分層的顯示(Layered presentation) 》
《z-index 默認(rèn)值引起的兼容性問題》
W3C Recommendation-Layered presentation

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/115225.html

相關(guān)文章

  • CSS魔法:說說Float那個被埋沒的志向

    摘要:時其寬度始終保持占滿寬度的態(tài)度。清除浮動就是為浮動影響的范圍劃邊界。那么可歸結(jié)為的父容器包裹所有子元素。注意屬性值不能為空白,否則無法清除浮動。 前言 ?定位系統(tǒng)中第一難理解就是Normal flow,而第二就非Float莫屬了,而Float難理解的原因有倆,1. 一開頭我們就用錯了;2. 它跟Normal flow靠得太近了。本文嘗試?yán)砬錐loat的特性和行為特征,若有紕漏望各位指正...

    legendmohe 評論0 收藏0
  • CSS魔法真的懂text-align

    摘要:深入本屆集團公司黨委由公司黨委由本屆集團公司黨委由公司黨委由組均是,而組則是。下英文泰文等的默認(rèn)對齊方式,下的默認(rèn)對齊方式等同于,采用增加減少象形文字間的距離。 前言 也許提及text-align你會想起水平居中,但除了這個你對它還有多少了解呢?本篇打算和大家一起來跟text-align來一次負(fù)距離的交往,你準(zhǔn)備好了嗎? text-align屬性詳解 The text-align C...

    tinylcy 評論0 收藏0
  • CSS魔法:重拾Border之——更廣闊的遐想

    摘要:也就是說我們操作的幾何公式中的未知變量,而具體的畫圖操作則由渲染引擎處理,而不是我們苦苦哀求設(shè)計師幫忙。 前言 ?當(dāng)CSS3推出border-radius屬性時我們是那么欣喜若狂啊,一想到終于不用再添加額外元素來模擬圓角了,但發(fā)現(xiàn)border-radius還分水平半徑和垂直半徑,然后又發(fā)現(xiàn)border-top-left/right-radius的水平半徑之和大于元素寬度時,實際值會按比...

    lily_wang 評論0 收藏0
  • CSS魔法:重拾Border之——解構(gòu)Border

    摘要:本系列將稍微深入探討一下那個貌似沒什么好玩的魔法堂重拾之解構(gòu)魔法堂重拾之圖片作邊框魔法堂重拾之不僅僅是圓角魔法堂重拾之更廣闊的遐想解構(gòu)說起我們自然會想起,而由條緊緊包裹著的邊組成,所以的最小操作單元是。 前言 ?當(dāng)CSS3推出border-radius屬性時我們是那么欣喜若狂啊,一想到終于不用再添加額外元素來模擬圓角了,但發(fā)現(xiàn)border-radius還分水平半徑和垂直半徑,然后又發(fā)現(xiàn)...

    lingdududu 評論0 收藏0
  • CSS魔法:Box-Shadow 沒那么簡單啦:)

    摘要:陰影距離原位置的垂直位移,正數(shù)表示向下移動,負(fù)數(shù)表示向上移動。實現(xiàn)原理純個人理解創(chuàng)建一個與元素尺寸一致的陰影盒子將陰影盒子定位到于元素重合,并位于元素之上水平和垂直各畫兩條線,分別跟元素重合共條分別記為根據(jù)和移動。 前言 說起box-shadow那第一個想法當(dāng)然就是用來實現(xiàn)陰影,其實它還能用于實現(xiàn)其他好玩的效果的,本篇就打算說說box-shadow的那些事。 二話不說看效果 showI...

    Galence 評論0 收藏0

發(fā)表評論

0條評論

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