5018
24875
今天,經過數小時的調試,我很難學到了以下規則:
如果父元素的z-index值為任何值,則無論您如何更改子元素的CSS,父元素都永遠無法覆蓋(堆疊在其子元素之上)
如何通過邏輯理解這種行為?在規格上嗎?
。容器 {
寬度:600像素;
高度:600像素;
背景色:鮭魚;
職位:相對
z索引:99;
padding-top:10像素;
}
h1 {
背景顏色:粉紅色;
職位:相對
z索引:-1;
字體家族:等寬字體;
}

1。如果我的z-index為正值,我永遠不會被父母覆蓋。

2。即使我的z-index是負數,但如果我的父母完全有z-index,我仍然永遠無法被覆蓋。

您需要了解兩件重要的事情:繪製順序和堆疊上下文。如果您參考該規範,則可以找到如何以及何時繪製元素。
堆疊由定位的後代組成的上下文,這些後代具有負z索引(不包括0),按z索引順序(最負數先),然後按樹順序排列。
按樹順序排列的所有已定位,不透明或轉換後代均屬於以下類別:
所有以“ z-index:auto”或“ z-index:0”排列的後代,按樹順序排列。
由z索引大於或等於1的定位後代形成的堆疊上下文,按z索引順序(最小的順序為小),然後按樹順序。
顯然,我們首先在步驟(3)繪製具有負z索引的元素,然後在步驟(8)繪製z索引等於0的元素,最後在步驟(9)繪製具有正z索引的元素。 ,這是合乎邏輯的。我們還可以閱讀規範的另一部分:
每個盒子都屬於一個堆疊上下文。給定堆疊上下文中的每個盒子都有一個整數堆疊級別,這是它在z軸上相對於同一堆疊上下文中其他盒子的位置。具有較高堆棧級別的框始終在具有較低堆棧級別的框前面格式化。箱子的堆疊高度可能為負。在堆疊上下文中具有相同堆疊級別的框將根據文檔樹的順序從下至上堆疊。
還
建立本地堆棧上下文的元素會生成一個具有兩個堆棧級別的框:一個用於它創建的堆棧上下文(始終為0),一個用於它所屬的堆棧上下文(由z-index屬性賦予)。
要了解何時繪製每個元素,您需要了解其堆疊上下文以及該堆疊上下文中的堆疊級別(由z-index定義)。您還需要知道該元素是否建立了堆棧上下文。這是棘手的部分,因為設置z-index可以做到這一點:
對於定位框,z-index屬性指定:
當前堆棧上下文中框的堆棧級別。
盒子是否建立堆疊環境
值具有以下含義:
<整數>
該整數是當前堆棧上下文中生成的框的堆棧級別。該框還建立了一個新的堆棧上下文。
汽車
當前堆棧上下文中生成的框的堆棧級別為0。除非框是根元素,否則框不會建立新的堆棧上下文。
現在,我們擁有所有信息,可以更好地理解每種情況。如果父元素的z-index值不是auto,則它將創建一個堆棧上下文,因此子元素將在其z-index為負(正或負)的任何內部繪畫。子元素的z-index會簡單地告訴我們父元素內部的繪畫順序(這涵蓋了您的第二點)。
現在,如果只有子元素的z索引為正,而我們在父元素上沒有設置任何內容,則考慮繪畫順序,子元素將在稍後(步驟(9))和父元素在步驟(8)進行繪製。在上面繪製父級的唯一邏輯方法是增加z-index,但是這樣做會使我們陷入先前的情況,父級將建立一個堆棧上下文,而子元素將屬於該上下文。
為子級設置正z索引時,無法將父級置於子級元素上方。如果將z-index設置為不同於auto的父元素(正數或負數),也無法使父項位於子項之上。1
我們唯一可以在其父項之下有一個子項的情況是在子元素上設置一個負的z-index並將父項保持在z-index:auto上,因此,該子項將不會創建堆疊上下文並按照繪製順序孩子將首先被繪畫。
除了z-index外,還有其他一些屬性可以創建堆棧上下文。如果遇到預期的堆疊順序,則還需要考慮這些屬性,以查看是否創建了堆疊上下文。
我們可以從以上總結得出一些重要事實:
堆棧上下文可以包含在其他堆棧上下文中,並一起創建堆棧上下文的層次結構。
每個堆棧上下文完全獨立於其同級:處理堆棧時僅考慮後代元素。
每個堆疊上下文都是獨立的:將元素的內容堆疊之後,將按照父堆疊上下文的堆疊順序考慮整個元素。參考
1:如果我們考慮使用3D變換,則有一些駭人聽聞的方法。
元素位於其父元素下的示例,即使該元素指定了z-index。
。盒子 {
位置:相對;
z-index:0;
高度:80像素;
背景:藍色;
轉換樣式:preserve-3d; /* 這個很重要 */
}
.box> div {
邊距:0 50px;
高度:100px;
背景:紅色;
z索引:-1; / *這將無濟於事* /
transform:translateZ(-1px); / *這會神奇* /
}
另一個示例,我們可以在另一個堆疊上下文中將一個元素放置在兩個元素之間: 。盒子 { 職位:相對 z索引:0; 高度:80px; 背景:藍色; } .box> div { 邊距:0 50px; 高度:100px; 背景:紅色; z索引:5; 轉換:translateZ(2px); } 。外部 { 高度:50px; 背景:綠色; 邊距:-10px 40px; 轉換:translateZ(1px); } 身體 { 轉換樣式:preserve-3d; }
我們還可以有一些瘋狂的堆疊順序,如下所示: 。盒子 { 寬度:100px; 高度:100px; 位置:絕對; } 身體 { 轉換樣式:preserve-3d; }
我們應該注意,由於轉換樣式,透視圖和轉換會影響position:absolute / fixed元素,因此使用此類技巧可能會有一些副作用。相關:父母的CSS過濾器破壞了孩子的位置 10 | 考慮這一點的一種好方法是每個父級都包含自己的堆棧上下文。同級元素共享父級的堆疊順序,因此可能彼此重疊。 子元素總是基於其父元素獲取堆棧上下文。因此,需要一個負的z-index值來將子級推到其父級(0)堆棧上下文的“後面”。 從元素的父級上下文中刪除元素的唯一方法是使用position:fixed,因為這實際上迫使其將窗口用於上下文。 1個 | Mozilla文檔確實說 z-index CSS屬性設置定位元素及其後代或flex項目的z順序。 這是另一個StackOverflow文章中有關子代與子代的一些其他邏輯。 2個 | 如何通過邏輯理解這種行為? 對我來說,很難用邏輯來理解你的問題。父母包含其子女。一個碗可以被另一個碗蓋住。但是,除非將湯從碗中取出,否則無法用碗蓋住湯。 z-Index設置重疊元素的順序。父母不能與孩子重疊。 ImhO完全合乎邏輯。 | 你的答案 StackExchange.ifUsing(“ editor”,function(){ StackExchange.using(“ externalEditor”,function(){ StackExchange.using(“ snippets”,function(){ StackExchange.snippets.init(); }); }); },“代碼段”); StackExchange.ready(function(){ var channelOptions = { 標籤:“” .split(“”), id:“ 1” }; initTagRenderer(“”。split(“”),“” .split(“”),channelOptions); StackExchange.using(“ externalEditor”,function(){ //如果啟用了摘要,則必須在摘要後觸發編輯器 如果(StackExchange.settings.snippets.snippetsEnabled){ StackExchange.using(“ snippets”,function(){ createEditor(); }); } 別的 { createEditor(); } }); 函數createEditor(){ StackExchange.prepareEditor({ useStacksEditor:否, heartbeatType:“答案”, autoActivateHeartbeat:否, convertImagesToLinks:是, noModals:是的, showLowRepImageUploadWarning:是的, 聲望:ToPostImages:10, bindNavPrevention:是的, 後綴:“”, imageUploader:{ brandingHtml:“採用\ u003ca href = \“ https://imgur.com/ \” \ u003e \ u003csvg class = \“ svg-icon \” width = \“ 50 \” height = \“ 18 \” viewBox = \“ 0 0 50 18 \” fill = \“ none \” xmlns = \“ http://www.w3.org/2000/svg \” \ u003e \ u003cpath d =“ \ M46.1709 9.17788C46.1709 8.26454 46.2665 7.94324 47.1084 7.58816C47.4091 7.46349 47.7169 7.36433 48.0099 7.26993C48.9099 6.97997 49.672 6.73443 49.672 5.93063C49.672 5.22043 48.9832 4.61182 48.1414 4.61182C47.4335 4.61182 46.7256 4.91628 46.0943 5.50789C45.73.6 4.631 43.1481 6.59048V11.9512C43.1481 13.2535 43.6264 13.8962 44.6595 13.8962C45.6924 13.8962 46.1709 13.2535 46.1709 11.9512V9.17788Z \“ / \ u003e \ u003cpath d = \” M32.492 10.1419C32.492 12.6954 34.1182 14.048437.0451 14.0484 41.5985 12.6954 41.5985 10.1419V6.59049C41.5985 5.28821 41.1394 4.66232 40.1061 4.66232C39.0732 4.66232 38.5948 5.28821 38.5948 6.59049V9.60062C38.5948 10.8521 38.2696 11.5455 37.0451 11.5455C35.8209 11.5455 35.4954 10.8 521 35.4954 9.60062V6.59049C35.4954 5.28821 35.0173 4.66232 34.0034 4.66232C32.9703 4.66232 32.492 5.28821 32.492 6.59049V10.1419Z \“ / \ u003e \ u003cpath fill-rule = \” evenodd \“ clip-rule = \” evenodd \“ d = \“ M25.6622 17.6335C27.8049 17.6335 29.3739 16.9402 30.2537 15.6379C30.8468 14.7755 30.9615 13.5579 30.9615 11.9512V6.59049C30.9615 5.28821 30.4833 4.66231 29.4502 4.66231C28.9913 4.66231 28.4555 4.94978 28.1109 5.50789C6.723 4.5608.787 .1369 4.56087 21.0134 6.57349 21.0134 9.27932C21.0134 11.9852 23.003 13.913 25.3754 13.913C26.5612 13.913 27.4607 13.4902 28.1109 12.6616C28.1109 12.7229 28.1161 12.779928.121 12.8346C28.1256 12.8854 28.1301 12.9342 28.1301 12.983C28.1301 14.4373 27.2502 15.2321 25.777 15.2321C24.8349 15.2321 24.1352 14.9821 23.5661 14.7787C23.176 14.6393 22.8472 14.5218 22.5437 14.5218C21.7977 14.5218 21.2429 15.0123633 ZM24.1317 9.27932C24.1317 7.94324 24.9928 7.09766 26.1024 7.09766C27.2119 7.09766 28.0918 7.94324 28.0918 9.27932C28.0918 10.6321 27.2311 11.5116 26.1024 11.5116C24.9737 11.5116 24.1317 10.6491 24.1317 9.27932Z \“ / \ u003d \ u003c 8045 11.9512C16.8045 13.2535 17.2637 13.8962 18.2965 13.8962C19.3298 13.8962 19.8079 13.2535 19.8079 11.9512V8.12928C19.8079 5.82936 18.4879 4.62866 16.4027 4.62866C15.1594 4.62866 14.279 4.98375 13.3609 5.88013C12.653 5.05154 11.65844.662 7.9466 5.5079C7.58314 4.9328 7.10506 4.66232 6.51203 4.66232C5.47873 4.66232 5.00066 5.28821 5.00066 6.59049V11.9512C5.00066 13.2535 5.47873 13.8962 6.51203 13.8962C7.54479 13.8962 8.0232 13.2535 8.0232 11.9512V8.90741C8.0232 7.58817 8.44431 6.91179 9.53458 6.91179C10.5104 6.91179 10.893 7.58817 10.893 8.94108V11.9512C10.893 13.2535 11.3711 13.8962 12.4044 13.8962C13.4375 13.8962 13.9157 13.25353.93.71 13.17.92.917.91911 6.91179C16.4027 6.91179 16.8045 7.58817 16.8045 8.94108V11.9512Z \“ / \ u003e \ u003cpath d = \” M3.31675 6.59049C3.31675 5.28821 2.83866 4.66232 1.82471 4.66232C0.791758 4.66232 0.313354 5.28821 0.313354 6.59049V11.935C0.3917354 13.8962 1.82471 13.8962C2.85798 13.8962 3.31675 13.2535 3.31675 11.9512V6.59049Z \“ / \ u003e \ u003cpath d =” \ M1.87209 0.400291C0.843612 0.400291 0 1.1159 0 1.98861C0 2.87869 0.822846 3.57676 1.87209 3.57676C2.90056 3.776763.7 1.98861C3.7234 1.1159 2.90056 0.400291 1.87209 0.400291Z \“ fill = \”#1BB76E \“ / \ u003e \ u003c / svg \ u003e \ u003c / a \ u003e”, contentPolicyHtml:“根據\ u003ca href = \“ https://stackoverflow.com/help/licensing \” \ u003ecc by-sa \ u003c / a \ u003e \ u003ca href = \“ https://stackoverflow.com獲得許可的用戶貢獻/ legal / content-policy \“ \ u003e(內容策略)\ u003c / a \ u003e”, allowUrls:是 }, onDemand:是的, dispatchSelector:“。discard-answer”。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。 ,立即ShowMarkdownHelp:true,enableTables:true,enableSnippets:true }); } }); 感謝您為Stack Overflow提供答案! 請務必回答問題。提供詳細信息並分享您的研究! 但是要避免... 尋求幫助,澄清或回答其他答案。 根據意見發表聲明;用參考或個人經驗來備份它們。 要了解更多信息,請參見我們撰寫出色答案的提示。 草稿已保存 草稿丟棄 註冊或登錄 StackExchange.ready(function(){ StackExchange.helpers.onClickDraftSave('#login-link'); }); 使用Google註冊 使用Facebook註冊 使用電子郵件和密碼註冊 提交 以訪客身份發布 姓名 電子郵件 必需,但從未顯示 StackExchange.ready( 功能 () { StackExchange.openid.initPostLogin('。new-post-login','https%3a%2f%2fstackoverflow.com%2fquestions%2f54897916%2fwhy-cant-an-element-with-az-index-value-cover-its- child%23new-answer','question_page'); } ); 以訪客身份發布 姓名 電子郵件 必需,但從未顯示 發表您的答案 丟棄 點擊“發布答案”,即表示您同意我們的服務條款,隱私政策和Cookie政策 不是您要找的答案?瀏覽標記為css css-position z-index的其他問題或提出您自己的問題。