white-space

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.

Die white-space CSS-Eigenschaft legt fest, wie white space innerhalb eines Elements behandelt wird.

Probieren Sie es aus

Die Eigenschaft spezifiziert zwei Dinge:

  • Ob und wie white space zusammengefasst wird.
  • Ob und wie Zeilen umbrechen.

Hinweis: Um Wörter innerhalb sich selbst zu brechen, verwenden Sie stattdessen overflow-wrap, word-break oder hyphens.

Syntax

css
/* Single keyword values */
white-space: normal;
white-space: nowrap;
white-space: pre;
white-space: pre-wrap;
white-space: pre-line;
white-space: break-spaces;

/* white-space-collapse and text-wrap shorthand values */
white-space: collapse balance;
white-space: preserve nowrap;

/* Global values */
white-space: inherit;
white-space: initial;
white-space: revert;
white-space: revert-layer;
white-space: unset;

Werte

Die Werte der white-space-Eigenschaft können als ein einziges Schlüsselwort aus der untenstehenden Liste angegeben werden, oder als zwei Werte, die eine Kurzform für die Eigenschaften white-space-collapse und text-wrap darstellen.

normal

Sequenzen von white space werden zusammengefasst. Neue Zeilenzeichen im Quelltext werden wie andere Leerzeichen behandelt. Zeilen werden nach Bedarf gebrochen, um Zeilenboxen zu füllen.

nowrap

Fasst white space wie der normal-Wert zusammen, unterdrückt jedoch Zeilenumbrüche (Textumbruch) innerhalb des Quelltexts.

pre

Sequenzen von white space werden beibehalten. Zeilen werden nur bei neuen Zeilenzeichen im Quelltext und bei <br>-Elementen gebrochen.

pre-wrap

Sequenzen von white space werden beibehalten. Zeilen werden bei neuen Zeilenzeichen, bei <br> und nach Bedarf gebrochen, um Zeilenboxen zu füllen.

pre-line

Sequenzen von white space werden zusammengefasst. Zeilen werden bei neuen Zeilenzeichen, bei <br> und nach Bedarf gebrochen, um Zeilenboxen zu füllen.

break-spaces

Das Verhalten ist identisch mit pre-wrap, außer dass:

  • Jede Sequenz von beibehaltenem white space nimmt immer Platz ein, einschließlich am Ende der Zeile.
  • Eine Möglichkeit zum Zeilenumbruch besteht nach jedem beibehaltenen white space-Zeichen, auch zwischen white space-Zeichen.
  • Solche beibehaltenen Leerzeichen nehmen Platz ein und hängen nicht, was die intrinsische Größe der Box beeinflusst (min-content-Größe und max-content-Größe).

Die folgende Tabelle fasst das Verhalten der verschiedenen white-space-Schlüsselwortwerte zusammen:

Neue Zeilen Leerzeichen und Tabs Textumbruch Leerzeichen am Zeilenende Andere Leerzeichen am Zeilenende
normal Zusammenfassen Zusammenfassen Umbruch Entfernen Hängen
nowrap Zusammenfassen Zusammenfassen Kein Umbruch Entfernen Hängen
pre Beibehalten Beibehalten Kein Umbruch Beibehalten Kein Umbruch
pre-wrap Beibehalten Beibehalten Umbruch Hängen Hängen
pre-line Beibehalten Zusammenfassen Umbruch Entfernen Hängen
break-spaces Beibehalten Beibehalten Umbruch Umbruch Umbruch

Ein Tabulator entspricht standardmäßig 8 Leerzeichen und kann mit der tab-size-Eigenschaft konfiguriert werden. Im Fall der Werte normal, nowrap und pre-line wird jeder Tabulator in ein Leerzeichen (U+0020) umgewandelt.

Hinweis: Es wird ein Unterschied zwischen Leerzeichen und anderen Leerzeichentrennzeichen gemacht. Diese werden wie folgt definiert:

Leerzeichen

Leerzeichen (U+0020), Tabs (U+0009) und Segmentumbrüche (wie z.B. neue Zeilen).

Andere Leerzeichentrennzeichen

Alle anderen in Unicode definierten Leerzeichentrennzeichen, außer denen, die bereits als Leerzeichen definiert sind.

Wo white space als hängend bezeichnet wird, kann dies die Größe der Box beeinflussen, wenn sie zur intrinsischen Größenbestimmung gemessen wird.

Zusammenfassen von white space

Formale Definition

Initialer Wertnormal
Anwendbar aufalle Elemente
VererbtJa
Berechneter Wertwie angegeben
Animationstypdiskret

Formale Syntax

white-space = 
normal |
pre |
nowrap |
pre-wrap |
break-spaces |
pre-line

Beispiele

Einfaches Beispiel

css
code {
  white-space: pre;
}

Zeilenumbrüche innerhalb von <pre>-Elementen

css
pre {
  white-space: pre-wrap;
}

In Aktion

Steuerung des Zeilenumbruchs in Tabellen

HTML

html
<table>
  <tr>
    <td></td>
    <td>Very long content that splits</td>
    <td class="nw">Very long content that don't split</td>
  </tr>
  <tr>
    <td class="nw">white-space:</td>
    <td>normal</td>
    <td>nowrap</td>
  </tr>
</table>

CSS

css
table {
  border-collapse: collapse;
  border: solid black 1px;
  width: 250px;
  height: 150px;
}
td {
  border: solid 1px black;
  text-align: center;
}
.nw {
  white-space: nowrap;
}

Ergebnis

Mehrere Zeilen im SVG-Text-Element

Die white-space-CSS-Eigenschaft kann verwendet werden, um mehrere Zeilen in einem <text>-Element zu erstellen, das standardmäßig nicht umbricht.

HTML

Der Text innerhalb des <text>-Elements muss in mehrere Zeilen aufgeteilt werden, damit die neuen Zeilen erkannt werden. Nach der ersten Zeile muss der restliche white space entfernt werden.

html
<svg viewBox="0 0 320 150">
  <text y="20" x="10">Here is an English paragraph
that is broken into multiple lines
in the source code so that it can
be more easily read and edited
in a text editor.
  </text>
</svg>

CSS

css
text {
  white-space: break-spaces;
}

Ergebnis

Spezifikationen

Specification
CSS Text Module Level 3
# white-space-property

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch