Stapeln von schwebenden Elementen
Für schwebende Elemente ist die Stapelreihenfolge etwas anders. Schwebende Elemente werden zwischen nicht-positionierten und positionierten Elementen platziert:
- Der Hintergrund und die Rahmen des Wurzelelements.
- Nachfolger nicht-positionierte Elemente, in der Reihenfolge ihres Auftretens im HTML.
- Schwebende Elemente.
- Nachfolger positionierte Elemente, in der Reihenfolge ihres Auftretens im HTML.
Sehen Sie sich Arten der Positionierung für eine Erklärung zu positionierten und nicht-positionierten Elementen an.
Hinweis:
Wenn ein opacity
-Wert auf ein nicht-positioniertes Element angewendet wird (z. B. DIV #4 im untenstehenden Beispiel), passiert etwas Merkwürdiges: Der Hintergrund und der Rahmen dieses Blocks erscheinen über den schwebenden und den positionierten Blöcken. Dies liegt an einem eigenartigen Teil der Spezifikationen: Das Anwenden eines opacity
-Werts erzeugt einen neuen Stapelkontext (siehe What No One Told You About Z-Index).
Beispiel
In diesem Beispiel können Sie sehen, dass der Hintergrund und der Rahmen des nicht-positionierten Elements (DIV #4) vollständig unbeeinflusst von den schwebenden Elementen sind, aber der Inhalt davon betroffen ist. Dies geschieht gemäß dem Standardverhalten von Floats, das durch eine hinzugefügte Regel zur obigen Liste gezeigt werden kann:
- Der Hintergrund und die Rahmen des Wurzelelements.
- Nachfolger nicht-positionierte Elemente, in der Reihenfolge ihres Auftretens im HTML.
- Schwebende Elemente.
- Nachfolger nicht-positionierte Inline-Elemente.
- Nachfolger positionierte Elemente, in der Reihenfolge ihres Auftretens im HTML.
HTML
<div id="abs1"><strong>DIV #1</strong><br />position: absolute;</div>
<div id="flo1"><strong>DIV #2</strong><br />float: left;</div>
<div id="flo2"><strong>DIV #3</strong><br />float: right;</div>
<br />
<div id="sta1"><strong>DIV #4</strong><br />no positioning</div>
<div id="abs2"><strong>DIV #5</strong><br />position: absolute;</div>
<div id="rel1"><strong>DIV #6</strong><br />position: relative;</div>
CSS
div {
padding: 10px;
text-align: center;
}
strong {
font-family: sans-serif;
}
#abs1 {
position: absolute;
width: 150px;
height: 200px;
top: 10px;
right: 140px;
border: 1px dashed #900;
background-color: #fdd;
}
#sta1 {
height: 100px;
border: 1px dashed #996;
background-color: #ffc;
margin: 0px 10px 0px 10px;
text-align: left;
}
#flo1 {
margin: 0px 10px 0px 20px;
float: left;
width: 150px;
height: 200px;
border: 1px dashed #090;
background-color: #cfc;
}
#flo2 {
margin: 0px 20px 0px 10px;
float: right;
width: 150px;
height: 200px;
border: 1px dashed #090;
background-color: #cfc;
}
#abs2 {
position: absolute;
width: 150px;
height: 100px;
top: 80px;
left: 100px;
border: 1px dashed #990;
background-color: #fdd;
}
#rel1 {
position: relative;
border: 1px dashed #996;
background-color: #cff;
margin: 0px 10px 0px 10px;
text-align: left;
}
Ergebnis
Siehe auch
- Stapeln ohne die
z-index
-Eigenschaft: Die Stapelregeln, die gelten, wennz-index
nicht verwendet wird. - Verwendung von z-index: Wie man
z-index
benutzt, um die Standard-Stapelreihenfolge zu ändern. - Stapelkontext: Anmerkungen zum Stapelkontext.
- Stapelkontext Beispiel 1: 2-Ebenen HTML-Hierarchie, z-index auf der letzten Ebene.
- Stapelkontext Beispiel 2: 2-Ebenen HTML-Hierarchie, z-index auf allen Ebenen.
- Stapelkontext Beispiel 3: 3-Ebenen HTML-Hierarchie, z-index auf der zweiten Ebene.