Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

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 ⁨Juli 2015⁩.

* Some parts of this feature may have varying levels of support.

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

Probieren Sie es aus

white-space: normal;
white-space: pre;
white-space: pre-wrap;
white-space: pre-line;
white-space: wrap;
white-space: collapse;
white-space: preserve nowrap;
<section class="default-example" id="default-example">
  <div id="example-element">
    <p>
      But ere she from the church-door stepped She smiled and told us why: 'It
      was a wicked woman's curse,' Quoth she, 'and what care I?' She smiled, and
      smiled, and passed it off Ere from the door she stept—
    </p>
  </div>
</section>
#example-element {
  width: 16rem;
}

#example-element p {
  border: 1px solid #c5c5c5;
  padding: 0.75rem;
  text-align: left;
}

Die Eigenschaft spezifiziert zwei Dinge:

  • Ob und wie Leerraum zusammengefasst wird.
  • Ob und wie Zeilen umbrochen werden.

Hinweis: Um Wörter innerhalb eines Wortes zu trennen, verwenden Sie stattdessen overflow-wrap, word-break oder hyphens.

Bestanteilende Eigenschaften

Diese Eigenschaft ist eine Kurzform für die folgenden CSS-Eigenschaften:

Hinweis: Die Spezifikation definiert eine dritte Bestandteil-Eigenschaft: white-space-trim, welche noch in keinem Browser implementiert ist.

Syntax

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

/* white-space-collapse and text-wrap-mode shorthand values */
white-space: nowrap;
white-space: wrap;
white-space: break-spaces;
white-space: collapse;
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 oder zwei Schlüsselwörter angegeben werden, die die Werte für die Eigenschaften white-space-collapse und text-wrap-mode repräsentieren, oder die folgenden speziellen Schlüsselwörter:

normal

Sequenzen von Leerraum werden zusammengefasst. Zeilenumbruchzeichen im Quelltext werden wie andere Leerzeichen behandelt. Zeilen werden bei Bedarf umgebrochen, um Zeilenboxen zu füllen. Entspricht collapse wrap.

pre

Sequenzen von Leerraum werden beibehalten. Zeilen werden nur an Zeilenumbruchzeichen im Quelltext und bei <br>-Elementen umbrochen. Entspricht preserve nowrap.

pre-wrap

Sequenzen von Leerraum werden beibehalten. Zeilen werden an Zeilenumbruchzeichen, bei <br> und bei Bedarf, um Zeilenboxen zu füllen, umbrochen. Entspricht preserve wrap.

pre-line

Sequenzen von Leerraum werden zusammengefasst. Zeilen werden an Zeilenumbruchzeichen, bei <br> und bei Bedarf, um Zeilenboxen zu füllen, umbrochen. Entspricht preserve-breaks wrap.

Hinweis: Die white-space-Eigenschaft als Kurzform ist eine relativ neue Funktion (siehe Browser-Kompatibilität). Ursprünglich hatte sie sechs Schlüsselwortwerte; nun wird der Wert nowrap stattdessen als Wert für text-wrap-mode interpretiert, während der Wert break-spaces als Wert für white-space-collapse interpretiert wird. Die oben genannten vier Schlüsselwörter sind immer noch spezifisch für white-space, haben jedoch Langform-Äquivalente. Die Änderung, white-space zu einer Kurzform zu machen, erweitert die akzeptablen Werte auf noch mehr Schlüsselwörter und Kombinationen, wie wrap und collapse.

Die folgende Tabelle fasst das Verhalten dieser vier white-space-Schlüsselwortwerte zusammen:

Neue Zeilen Leerzeichen und Tabulatoren Textumbruch Leerzeichen am Zeilenende Andere Leerraum-Trennzeichen am Zeilenende
normal Zusammenfassen Zusammenfassen 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

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

Hinweis: Es wird zwischen Leerzeichen und anderen Leerraum-Trennzeichen unterschieden. Diese sind wie folgt definiert:

Leerzeichen

Leerzeichen (U+0020), Tabulatoren (U+0009) und Segmentumbrüche (wie Zeilenumbruchzeichen).

Andere Leerraum-Trennzeichen

Alle anderen Leerraum-Trennzeichen, die in Unicode definiert sind, außer denen, die bereits als Leerzeichen definiert sind.

Wo Leerraum hängt, kann dies die Größe der Box beeinflussen, wenn sie für die intrinsische Größenbestimmung gemessen wird.

Formale Definition

Anfangswertnormal
Anwendbar aufalle Elemente
VererbtJa
Berechneter Wertwie angegeben
Animationstypdiskret

Formale Syntax

white-space = 
normal |
pre |
pre-wrap |
pre-line |
<'white-space-collapse'> || <'text-wrap-mode'> || <'white-space-trim'>

<white-space-collapse> =
collapse |
discard |
preserve |
preserve-breaks |
preserve-spaces |
break-spaces

<text-wrap-mode> =
wrap |
nowrap

<white-space-trim> =
none |
discard-before || discard-after || discard-inner

Beispiele

Grundlegendes Beispiel

css
code {
  white-space: pre;
}

Zeilenumbrüche innerhalb von <pre>-Elementen

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

In Aktion

Zeilenumbruchsteuerung in Tabellen

HTML

html
<table>
  <tbody>
    <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>
  </tbody>
</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 in einem 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 im <text>-Element muss in mehrere Zeilen aufgeteilt werden, damit die neuen Zeilen erkannt werden. Nach der ersten Zeile muss der restliche Leerraum 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 4
# white-space-property
Scalable Vector Graphics (SVG) 2
# TextWhiteSpace

Browser-Kompatibilität

Siehe auch