display
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
* Some parts of this feature may have varying levels of support.
Die display
-Eigenschaft von CSS legt fest, ob ein Element als Block- oder Inline-Box behandelt wird und welches Layout für seine Kinder verwendet wird, wie zum Beispiel das Flow-Layout, Grid oder Flex.
Formal legt die display
-Eigenschaft die inneren und äußeren Display-Typen eines Elements fest. Der äußere Typ bestimmt die Teilnahme eines Elements am Flow-Layout; der innere Typ legt das Layout der Kinder fest. Einige Werte von display
sind in ihren eigenen individuellen Spezifikationen vollständig definiert; zum Beispiel sind die Details, was passiert, wenn display: flex
deklariert wird, in der CSS Flexible Box Model-Spezifikation definiert.
Probieren Sie es aus
Syntax
/* precomposed values */
display: block;
display: inline;
display: inline-block;
display: flex;
display: inline-flex;
display: grid;
display: inline-grid;
display: flow-root;
/* box generation */
display: none;
display: contents;
/* multi-keyword syntax */
display: block flex;
display: block flow;
display: block flow-root;
display: block grid;
display: inline flex;
display: inline flow;
display: inline flow-root;
display: inline grid;
/* other values */
display: table;
display: table-row; /* all table elements have an equivalent CSS display value */
display: list-item;
/* Global values */
display: inherit;
display: initial;
display: revert;
display: revert-layer;
display: unset;
Die CSS-Eigenschaft display
wird unter Verwendung von Schlüsselwortwerten spezifiziert.
Gruppierte Werte
Die Schlüsselwortwerte können in sechs Kategorien gruppiert werden.
Outside
<display-outside>
-
Diese Schlüsselwörter spezifizieren den äußeren Anzeige-Typ des Elements, wodurch dessen Rolle im Fluss-Layout festgelegt wird:
block
-
Das Element erzeugt eine Block-Box, die sowohl vor als auch nach dem Element Zeilenumbrüche erzeugt, wenn es im normalen Fluss ist.
inline
-
Das Element erzeugt eine oder mehrere Inline-Boxen, die vor oder nach sich selbst keine Zeilenumbrüche erzeugen. Im normalen Fluss befindet sich das nächste Element auf derselben Linie, wenn Platz vorhanden ist.
Hinweis:
Wenn Browser, die die Multi-Schlüsselwort-Syntax unterstützen, eine Display-Eigenschaft mit nur einem äußeren Wert (z.B. display: block
oder display: inline
) vorfinden, wird der innere Wert auf flow
gesetzt (z.B. display: block flow
und display: inline flow
).
Hinweis:
Um sicherzustellen, dass Layouts in älteren Browsern funktionieren, können Sie die Einwert-Syntax verwenden, zum Beispiel könnte display: inline flex
das folgende Fallback haben
.container {
display: inline-flex;
display: inline flex;
}
Weitere Informationen finden Sie unter Using the multi-keyword syntax with CSS display.
Inside
<display-inside>
-
Diese Schlüsselwörter spezifizieren den inneren Anzeige-Typ des Elements, der den Typ des Formatierungskontexts definiert, in dem seine Inhalte angeordnet sind (sofern es sich um ein nicht ersetztes Element handelt):
flow
-
Das Element ordnet seine Inhalte mithilfe des Flusslayouts (Block-und-Inline-Layout) an.
Wenn sein äußerer Anzeigetyp
inline
ist und es an einem Block- oder Inline-Formatierungskontext teilnimmt, erzeugt es eine Inline-Box. Andernfalls erzeugt es eine Block-Box.Abhängig vom Wert anderer Eigenschaften (wie
position
,float
oderoverflow
) und davon, ob es selbst an einem Block- oder Inline-Formatierungskontext teilnimmt, wird entweder ein neuer Block-Formatierungskontext (BFC) für seine Inhalte erstellt oder seine Inhalte in den übergeordneten Formatierungskontext integriert. flow-root
-
Das Element erzeugt eine Block-Box, die einen neuen Block-Formatierungskontext erstellt, der definiert, wo die Formatierungswurzel liegt.
table
-
Diese Elemente verhalten sich wie HTML-
<table>
-Elemente. Es definiert eine blocklevel-Box. flex
-
Das Element verhält sich wie ein blocklevel-Element und ordnet seinen Inhalt gemäß dem Flexbox-Modell an.
grid
-
Das Element verhält sich wie ein blocklevel-Element und ordnet seinen Inhalt gemäß dem Grid-Modell an.
ruby
-
Das Element verhält sich wie ein inline-level-Element und ordnet seinen Inhalt gemäß dem Ruby-Formatierungsmodell an. Es verhält sich wie die entsprechenden HTML-
<ruby>
-Elemente.
Hinweis:
Wenn Browser, die die Multi-Schlüsselwort-Syntax unterstützen, eine Display-Eigenschaft mit nur einem inneren Wert (z.B. display: flex
oder display: grid
) vorfinden, wird der äußere Wert auf block
gesetzt (z.B. display: block flex
und display: block grid
).
List Item
<display-listitem>
-
Das Element erzeugt eine Block-Box für den Inhalt und eine separate Listenpunkte-Inline-Box.
Ein einzelner Wert von list-item
bewirkt, dass sich das Element wie ein Listeneintrag verhält.
Dies kann zusammen mit list-style-type
und list-style-position
verwendet werden.
list-item
kann auch mit jedem <display-outside>
-Schlüsselwort und dem flow
oder flow-root
<display-inside>
-Schlüsselwort kombiniert werden.
Hinweis:
In Browsern, die die Multi-Schlüsselwort-Syntax unterstützen, wird, wenn kein innerer Wert angegeben ist, standardmäßig flow
gesetzt.
Wenn kein äußerer Wert angegeben ist, hat die Hauptbox einen äußeren Anzeige-Typ von block
.
Internal
<display-internal>
-
Einige Layout-Modelle wie
table
undruby
haben eine komplexe interne Struktur mit mehreren verschiedenen Rollen, die ihre Kinder und Nachkommen erfüllen können. Dieser Abschnitt definiert jene "internen" Anzeige-Werte, die nur innerhalb dieses spezifischen Layout-Modus Bedeutung haben.table-row-group
-
Diese Elemente verhalten sich wie HTML-
<tbody>
-Elemente. table-header-group
-
Diese Elemente verhalten sich wie HTML-
<thead>
-Elemente. -
Diese Elemente verhalten sich wie HTML-
<tfoot>
-Elemente. table-row
-
Diese Elemente verhalten sich wie HTML-
<tr>
-Elemente. table-cell
-
Diese Elemente verhalten sich wie HTML-
<td>
-Elemente. table-column-group
-
Diese Elemente verhalten sich wie HTML-
<colgroup>
-Elemente. table-column
-
Diese Elemente verhalten sich wie HTML-
<col>
-Elemente. -
Diese Elemente verhalten sich wie HTML-
<caption>
-Elemente. ruby-base
-
Diese Elemente verhalten sich wie HTML-
<rb>
-Elemente. ruby-text
-
Diese Elemente verhalten sich wie HTML-
<rt>
-Elemente. ruby-base-container
-
Diese Elemente werden als anonyme Boxen erzeugt.
ruby-text-container
-
Diese Elemente verhalten sich wie HTML-
<rtc>
-Elemente.
Box
<display-box>
-
Diese Werte definieren, ob ein Element überhaupt Anzeige-Boxen erzeugt.
contents
-
Diese Elemente erzeugen selbst keine spezifische Box. Sie werden durch ihre Pseudo-Box und ihre Kinder-Boxen ersetzt. Bitte beachten Sie, dass die CSS Display Level 3 Spec definiert, wie der Wert
contents
sich auf "ungewöhnliche Elemente" auswirken sollte – Elemente, die nicht rein durch CSS-Box-Konzepte wie ersetzte Elemente gerendert werden. Weitere Details finden Sie unter Anhang B: Effekte von display: contents auf Ungewöhnliche Elemente. none
-
Schaltet die Anzeige eines Elements aus, sodass es keinen Einfluss auf das Layout hat (das Dokument wird gerendert, als ob das Element nicht existiert). Alle Nachkommenelemente haben ebenfalls ihre Anzeige ausgeschaltet. Um ein Element den Platz einnehmen zu lassen, den es normalerweise einnehmen würde, ohne tatsächlich irgendetwas anzuzeigen, verwenden Sie stattdessen die
visibility
-Eigenschaft.
Precomposed
<display-legacy>
-
CSS 2 verwendete eine Single-Keyword, vorkomponierte Syntax für die
display
-Eigenschaft, die separate Schlüsselwörter für blocklevel- und inline-level-Varianten des gleichen Layout-Modus erforderte.inline-block
-
Das Element erzeugt eine Block-Box, die mit dem umgebenden Inhalt geflossen wird, als ob es eine einzelne Inline-Box wäre (verhält sich ähnlich wie ein ersetztes Element).
Es ist äquivalent zu
inline flow-root
. inline-table
-
Der
inline-table
-Wert hat keine direkte Zuordnung in HTML. Es verhält sich wie ein HTML-<table>
-Element, jedoch als Inline-Box statt einer Blocklevel-Box. Innerhalb der Tabellenbox befindet sich ein Blocklevel-Kontext.Es ist äquivalent zu
inline table
. inline-flex
-
Das Element verhält sich wie ein inline-level-Element und ordnet seinen Inhalt gemäß dem Flexbox-Modell an.
Es ist äquivalent zu
inline flex
. inline-grid
-
Das Element verhält sich wie ein inline-level-Element und ordnet seinen Inhalt gemäß dem Grid-Modell an.
Es ist äquivalent zu
inline grid
.
Welche Syntax sollten Sie verwenden?
Das CSS display module beschreibt eine Multi-Schlüsselwort-Syntax für Werte, die Sie mit der display
-Eigenschaft verwenden können, um äußeres und inneres Display explizit zu definieren.
Die Single-Keyword-Werte (vorkomponierte <display-legacy>
-Werte) werden für die Rückwärtskompatibilität unterstützt.
Zum Beispiel können Sie mit zwei Werten einen Inline-Flex-Container wie folgt spezifizieren:
.container {
display: inline flex;
}
Dies kann auch mit dem traditionellen Einwert spezifiziert werden:
.container {
display: inline-flex;
}
Für weitere Informationen zu diesen Änderungen siehe den Using the multi-keyword syntax with CSS display Leitfaden.
Global
/* Global values */
display: inherit;
display: initial;
display: unset;
Beschreibung
Die einzelnen Seiten für die verschiedenen Typen von Werten, die display
haben kann, zeigen mehrere Beispiele für diese Werte in Aktion - siehe den Syntax Abschnitt. Darüber hinaus sollten Sie das folgende Material in Erwägung ziehen, das die verschiedenen Werte von display
ausführlich behandelt.
Multi-Schlüsselwort-Werte
CSS Fluss-Layout (display: block, display: inline)
display: flex
- Grundlegende Konzepte von Flexbox
- Ausrichten von Elementen in einem Flex-Container
- Kontrolle der Verhältnisse von Flex-Elementen entlang der Hauptachse
- Beherrschen des Umbruchs von Flex-Elementen
- Anordnung von Flex-Elementen
- Beziehung von Flexbox zu anderen Layout-Methoden
- Typische Anwendungsfälle von Flexbox
display: grid
- Grundlegende Konzepte des Grid-Layouts
- Beziehung zu anderen Layout-Methoden
- Zeilenbasierte Platzierung
- Grid-Template-Bereiche
- Layout mit benannten Grid-Linien
- Automatische Platzierung im Grid-Layout
- Box-Ausrichtung im Grid-Layout
- Grids, logische Werte und Schreibmodi
- CSS Grid-Layout und Barrierefreiheit
- CSS Grid-Layout und Progressive Enhancement
- Häufige Layouts mit Grids umsetzen
Animieren von display
Unterstützende Browser animieren display
mit einem diskreten Animationstyp. Dies bedeutet im Allgemeinen, dass die Eigenschaft während der Animation zwischen zwei Werten zu 50% umschaltet.
Es gibt eine Ausnahme, die auftritt, wenn display: none
von oder zu einem anderen Wert animiert wird. In diesem Fall wird der Browser zwischen den beiden Werten umschalten, sodass der animierte Inhalt während der gesamten Animationsdauer angezeigt wird. So zum Beispiel:
- Beim Animieren von
display
vonnone
zublock
(oder einem anderen sichtbarendisplay
-Wert) schaltet der Wert bei0%
der Animationsdauer aufblock
, damit er die ganze Zeit über sichtbar ist. - Beim Animieren von
display
vonblock
(oder einem anderen sichtbarendisplay
-Wert) zunone
, schaltet der Wert bei100%
der Animationsdauer aufnone
, damit er die ganze Zeit über sichtbar ist.
Dieses Verhalten ist nützlich, um Eintritts-/Austrittsanimationen zu erstellen, bei denen Sie beispielsweise einen Container mit display: none
aus dem DOM entfernen, jedoch mit opacity ausblenden möchten, anstatt sofort zu verschwinden.
Beim Animieren von display
mit CSS-Animationen müssen Sie den Ausgangswert von display
in einem expliziten Schlüsselbild bereitstellen (beispielsweise mit 0%
oder from
). Siehe Using CSS animations für ein Beispiel.
Beim Animieren von display
mit CSS-Übergängen sind zwei zusätzliche Funktionen erforderlich:
@starting-style
bietet Ausgangswerte für Eigenschaften, von denen Sie bei erstmaliger Anzeige des animierten Elements aus übergehen möchten. Dies ist erforderlich, um unerwartetes Verhalten zu vermeiden. Standardmäßig werden CSS-Übergänge nicht bei der ersten Stilaktualisierung eines Elements oder beim Wechsel desdisplay
-Typs vonnone
zu einem anderen Typ ausgelöst.transition-behavior: allow-discrete
muss in dertransition-property
-Deklaration (oder imtransition
-Kurzschreibweise) gesetzt werden, umdisplay
-Übergänge zu aktivieren.
Für Beispiele zu Übergängen der display
-Eigenschaft siehe die Seiten @starting-style
und transition-behavior
.
Barrierefreiheit
display: none
Die Verwendung eines display
-Wertes von none
auf einem Element entfernt es aus dem Barrierefreiheit-Baum. Dies führt dazu, dass das Element und alle seine Nachkommenelemente nicht mehr von Screenreader-Technologie angekündigt werden.
Wenn Sie das Element visuell ausblenden möchten, ist eine zugänglichere Alternative die Verwendung einer Kombination von Eigenschaften, um es visuell vom Bildschirm zu entfernen, es aber dennoch für unterstützende Technologien wie Screenreader verfügbar zu machen.
Während display: none
Inhalte aus dem Barrierefreiheit-Baum ausblendet, werden Elemente, die ausgeblendet sind, aber von sichtbaren Elementen aria-describedby
oder aria-labelledby
-Attribute referenziert werden, immer noch unterstützenden Technologien zugänglich gemacht.
display: contents
Aktuelle Implementierungen in einigen Browsern werden jedes Element mit einem display
-Wert von contents
(aber die Nachkommen bleiben) aus dem Barrierefreiheit-Baum entfernen. Dies führt dazu, dass das Element selbst nicht mehr von Screenreader-Technologie angekündigt wird. Dies ist ein fehlerhaftes Verhalten gemäß der CSS-Spezifikation.
Tabellen
In einigen Browsern wird das Ändern des display
-Wertes eines <table>
-Elements in block
, grid
oder flex
dessen Darstellung im Barrierefreiheit-Baum verändern. Dies führt dazu, dass die Tabelle nicht mehr korrekt von Screenreader-Technologie angekündigt wird.
Formale Definition
Anfangswert | inline |
---|---|
Anwendbar auf | alle Elemente |
Vererbt | Nein |
Berechneter Wert | wie der angegebene Wert, außer für positionierte und umfließende Elemente und das Wurzelelement. In beiden Fällen kann der berechnete Wert ein Schlüsselwort sein, das nicht dem angegebenen entspricht. |
Animationstyp | Discrete behavior except when animating to or from none is visible for the entire duration |
Formale Syntax
display =
[ <display-outside> || <display-inside> ] |
<display-listitem> |
<display-internal> |
<display-box> |
<display-legacy> |
<display-outside> || [ <display-inside> | math ]
<display-outside> =
block |
inline |
run-in
<display-inside> =
flow |
flow-root |
table |
flex |
grid |
ruby
<display-listitem> =
<display-outside>? &&
[ flow | flow-root ]? &&
list-item
<display-internal> =
table-row-group |
table-header-group |
table-footer-group |
table-row |
table-cell |
table-column-group |
table-column |
table-caption |
ruby-base |
ruby-text |
ruby-base-container |
ruby-text-container
<display-box> =
contents |
none
<display-legacy> =
inline-block |
inline-table |
inline-flex |
inline-grid
Beispiele
Vergleich von display-Werten
In diesem Beispiel haben wir zwei Block-Container-Elemente, jedes mit drei Inline-Kindern. Darunter haben wir ein Auswahlmenü, mit dem Sie verschiedene display
-Werte auf die Container anwenden können, sodass Sie vergleichen und gegenüberstellen können, wie die verschiedenen Werte das Layout des Elements und das seiner Kinder beeinflussen.
Wir haben padding
und background-color
auf die Container und ihre Kinder angewendet, damit es einfacher ist, den Effekt der display-Werte zu sehen.
HTML
<article class="container">
<span>First</span>
<span>Second</span>
<span>Third</span>
</article>
<article class="container">
<span>First</span>
<span>Second</span>
<span>Third</span>
</article>
<div>
<label for="display">Choose a display value:</label>
<select id="display">
<option selected>block</option>
<option>block flow</option>
<option>inline</option>
<option>inline flow</option>
<option>flow</option>
<option>flow-root</option>
<option>block flow-root</option>
<option>table</option>
<option>block table</option>
<option>flex</option>
<option>block flex</option>
<option>grid</option>
<option>block grid</option>
<option>list-item</option>
<option>block flow list-item</option>
<option>inline flow list-item</option>
<option>block flow-root list-item</option>
<option>inline flow-root list-item</option>
<option>contents</option>
<option>none</option>
<option>inline-block</option>
<option>inline flow-root</option>
<option>inline-table</option>
<option>inline table</option>
<option>inline-flex</option>
<option>inline flex</option>
<option>inline-grid</option>
<option>inline grid</option>
</select>
</div>
CSS
html {
font-family: helvetica, arial, sans-serif;
letter-spacing: 1px;
padding-top: 10px;
}
article {
background-color: red;
}
article span {
background-color: black;
color: white;
margin: 1px;
}
article,
span {
padding: 10px;
border-radius: 7px;
}
article,
div {
margin: 20px;
}
JavaScript
const articles = document.querySelectorAll(".container");
const select = document.querySelector("select");
function updateDisplay() {
articles.forEach((article) => {
article.style.display = select.value;
});
}
select.addEventListener("change", updateDisplay);
updateDisplay();
Ergebnis
Beachten Sie, dass einige Multi-Schlüsselwort-Werte zur Veranschaulichung hinzugefügt werden, die folgende Äquivalente haben:
block
=block flow
inline
=inline flow
flow
=block flow
flow-root
=block flow-root
table
=block table
flex
=block flex
grid
=block grid
list-item
=block flow list-item
inline-block
=inline flow-root
inline-table
=inline table
inline-flex
=inline flex
inline-grid
=inline grid
Weitere Beispiele finden Sie auf den Seiten für jeden separaten Anzeigetyp unter Gruppierte Werte.
Spezifikationen
Specification |
---|
CSS Display Module Level 3 # the-display-properties |
Browser-Kompatibilität
BCD tables only load in the browser