overflow
Die overflow
CSS-Kurzschreibweise legt das gewünschte Verhalten fest, wenn Inhalte in der horizontalen und/oder vertikalen Richtung nicht in den Innenabstand eines Elements passen (überlaufen).
Probieren Sie es aus
Bestandteil-Eigenschaften
Diese Eigenschaft ist eine Kurzform für die folgenden CSS-Eigenschaften:
Syntax
/* Keyword values */
overflow: visible;
overflow: hidden;
overflow: clip;
overflow: scroll;
overflow: auto;
overflow: hidden visible;
/* Global values */
overflow: inherit;
overflow: initial;
overflow: revert;
overflow: revert-layer;
overflow: unset;
Die overflow
-Eigenschaft wird als ein oder zwei <overflow>
Schlüsselwort-Werte angegeben. Wenn nur ein Schlüsselwort angegeben wird, werden sowohl overflow-x
als auch overflow-y
auf denselben Wert gesetzt. Wenn zwei Schlüsselwörter angegeben werden, gilt der erste Wert für overflow-x
in horizontaler Richtung und der zweite für overflow-y
in vertikaler Richtung.
Werte
visible
-
Überlaufende Inhalte werden nicht abgeschnitten und können außerhalb des Innenabstands des Elements sichtbar sein. Der Elementkasten ist keine Scroll-Container. Dies ist der Standardwert der
overflow
-Eigenschaft. -
Überlaufende Inhalte werden am Innenabstand des Elements abgeschnitten. Es gibt keine Scrollleisten und die abgeschnittenen Inhalte sind nicht sichtbar (d. h. die abgeschnittenen Inhalte sind verborgen), aber die Inhalte existieren weiterhin. Benutzeragenten fügen keine Scrollleisten hinzu und erlauben Benutzern auch nicht, die Inhalte außerhalb des abgeschnittenen Bereichs durch Aktionen wie Ziehen auf einem Touchscreen oder Verwenden des Mausrads zu sehen. Die Inhalte können programmgesteuert gescrollt werden (zum Beispiel durch Verlinken mit Ankertext, durch Tabben zu einem verborgenen, aber fokussierbaren Element oder durch Setzen des Wertes der
scrollLeft
-Eigenschaft oder derscrollTo()
-Methode), in diesem Fall ist der Elementkasten ein Scroll-Container. clip
-
Überlaufender Inhalt wird an der overflow clip Kante des Elements abgeschnitten, die mit der
overflow-clip-margin
-Eigenschaft definiert wird. Dadurch wird der Inhalt bis zur<length>
-Wert vonoverflow-clip-margin
oder auf0px
, wenn nicht gesetzt, über den Innenabstand des Elements hinaus überlaufen. Überlaufende Inhalte außerhalb des abgeschnittenen Bereichs sind nicht sichtbar, Benutzeragenten fügen keine Scrollleiste hinzu und programmgesteuertes Scrollen wird ebenfalls nicht unterstützt. Es wird kein neuer Formatierungskontext erstellt. Um einen Formatierungskontext zu erstellen, verwenden Sieoverflow: clip
zusammen mitdisplay: flow-root
. Der Elementkasten ist kein Scroll-Container. scroll
-
Überlaufender Inhalt wird am Innenabstand des Elements abgeschnitten und kann in den Ansichtsbereich gescrollt werden, indem Scrollleisten verwendet werden. Benutzeragenten zeigen Scrollleisten an, unabhängig davon, ob Inhalte überlaufen, sodass in horizontaler und vertikaler Richtung, wenn der Wert auf beide Richtungen anwendbar ist. Die Verwendung dieses Schlüsselworts kann daher verhindern, dass Scrollleisten erscheinen und verschwinden, während sich der Inhalt ändert. Drucker können dennoch überlaufende Inhalte drucken. Der Elementkasten ist ein Scroll-Container.
auto
-
Überlaufender Inhalt wird am Innenabstand des Elements abgeschnitten und kann mit Scrollleisten in den Ansichtsbereich gescrollt werden. Anders als bei
scroll
, zeigen Benutzeragenten Scrollleisten nur an, wenn der Inhalt überläuft. Wenn der Inhalt in den Innenabstand des Elements passt, sieht es genauso aus wie mitvisible
, erstellt jedoch dennoch einen neuen Formatierungskontext. Der Elementkasten ist ein Scroll-Container.
Hinweis: Der Schlüsselwort-Wert overlay
ist ein veralteter Wertalias für auto
. Mit overlay
werden die Scrollleisten über den Inhalten gezeichnet, statt Platz einzunehmen.
Beschreibung
Überlaufoptionen umfassen das Verbergen von Überlaufinhalten, das Aktivieren von Scrollleisten zum Anzeigen von Überlaufinhalten oder das Anzeigen der Inhalte, die aus einem Elementkasten in den umgebenden Bereich hinausfließen, sowie deren Kombinationen.
Die folgenden Nuancen sollten bei der Verwendung der verschiedenen Schlüsselwörter für overflow
beachtet werden:
- Das Festlegen eines anderen Werts als
visible
(dem Standard) oderclip
füroverflow
erstellt einen neuen Block-Formatierungskontext. Dies ist aus technischen Gründen notwendig; wenn ein Float mit einem scrollbaren Element überlagert wird, würde er den Inhalt nach jedem Scroll-Schritt zwingend neu umbrechen, was zu einem langsamen Scroll-Erlebnis führen würde. - Damit eine
overflow
-Einstellung den gewünschten Effekt erzielt, muss das Block-Level-Element entweder eine festgelegte Höhe (height
odermax-height
) haben, wenn der Überlauf in vertikaler Richtung erfolgt, eine festgelegte Breite (width
odermax-width
), wenn der Überlauf in horizontaler Richtung erfolgt, eine festgelegte Blockgröße (block-size
odermax-block-size
), wenn der Überlauf in Blockrichtung erfolgt, oder eine festgelegte Inline-Größe (inline-size
odermax-inline-size
) oderwhite-space
aufnowrap
festgelegt, wenn der Überlauf in Inline-Richtung erfolgt. - Das Festlegen von Overflow auf
visible
in eine Richtung (d. h.overflow-x
oderoverflow-y
), wenn es in der anderen Richtung nicht aufvisible
oderclip
eingestellt ist, führt dazu, dass der Wertvisible
sich wieauto
verhält. - Wenn Overflow in eine Richtung auf
clip
eingestellt ist und nicht alsvisible
oderclip
in der anderen Richtung, verhält sich der Wertclip
wiehidden
. - Die JavaScript-Eigenschaft
Element.scrollTop
kann verwendet werden, um durch Inhalte in einem Scroll-Container zu scrollen, außer wennoverflow
aufclip
gesetzt ist.
Formale Definition
Initialer Wert | visible |
---|---|
Anwendbar auf | Block-containers, flex containers, and grid containers |
Vererbt | Nein |
Berechneter Wert | wie die jeweiligen Kurzschreibweisen:
|
Animationstyp | diskret |
Formale Syntax
Barrierefreiheit
Ein scrollbarer Inhaltsbereich kann von einem nur Tastatur benutzenden Benutzer nicht gescrollt werden, mit der Ausnahme von Benutzern auf Firefox (das den Container standardmäßig mit der Tastatur fokussierbar macht).
Als Entwickler werden Sie nicht-Firefox Tastatur-Nutzer, um den Container zu scrollen, ein tabindex
geben müssen, indem Sie tabindex="0"
verwenden. Leider wird bei einem von einem Screenreader gefundenen Tab-Stopp der gesamte Inhalt des Containers ohne Kontext für den Tab-Stopp angekündigt. Das Zuweisen einer geeigneten WAI-ARIA-Rolle (zum Beispiel role="region"
) und eines zugänglichen Namens (über aria-label
oder aria-labelledby
) kann dies mildern.
Beispiele
Ergebnisse verschiedener Overflow-Schlüsselwörter demonstrieren
HTML
<div>
<code>visible</code>
<p class="visible">
Maya Angelou: "I've learned that people will forget what you said, people
will forget what you did, but people will never forget how you made them
feel."
</p>
</div>
<div>
<code>hidden</code>
<p class="hidden">
Maya Angelou: "I've learned that people will forget what you said, people
will forget what you did, but people will never forget how you made them
feel."
</p>
</div>
<div>
<code>clip</code>
<p class="clip">
Maya Angelou: "I've learned that people will forget what you said, people
will forget what you did, but people will never forget how you made them
feel."
</p>
</div>
<div>
<code>scroll</code>
<p class="scroll">
Maya Angelou: "I've learned that people will forget what you said, people
will forget what you did, but people will never forget how you made them
feel."
</p>
</div>
<div>
<code>auto</code>
<p class="auto">
Maya Angelou: "I've learned that people will forget what you said, people
will forget what you did, but people will never forget how you made them
feel."
</p>
</div>
<div>
<code>overlay</code>
<p class="overlay">
Maya Angelou: "I've learned that people will forget what you said, people
will forget what you did, but people will never forget how you made them
feel."
</p>
</div>
CSS
p.visible {
overflow: visible;
}
p.hidden {
overflow: hidden;
}
p.clip {
overflow: clip;
overflow-clip-margin: 1em;
}
p.scroll {
overflow: scroll;
}
p.auto {
overflow: auto;
}
p.overlay {
overflow: overlay;
}
Ergebnis
Spezifikationen
Specification |
---|
CSS Overflow Module Level 3 # propdef-overflow |
Browser-Kompatibilität
BCD tables only load in the browser
Siehe auch
overflow-x
,overflow-y
overflow-block
,overflow-clip-margin
,overflow-inline
clip
,display
,text-overflow
,white-space
- CSS overflow
- Tastatur-nur Scrollbereiche auf adrianroselli.com (2022)