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

View in English Always switch to English

columns

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since März 2017.

Die columns CSS Kurzform-Eigenschaft legt die maximale Anzahl der Spalten fest, die beim Zeichnen des Inhalts eines Elements verwendet werden sollen, zusammen mit der minimalen Breite und der maximalen Höhe der Spalten des Elements.

Probieren Sie es aus

columns: 2;
columns: 6rem auto;
columns: 12em;
columns: 3;
<section id="default-example">
  <p id="example-element">
    London. Michaelmas term lately over, and the Lord Chancellor sitting in
    Lincoln's Inn Hall. Implacable November weather. As much mud in the streets
    as if the waters had but newly retired from the face of the earth, and it
    would not be wonderful to meet a Megalosaurus, forty feet long or so,
    waddling like an elephantine lizard up Holborn Hill.
  </p>
</section>
#example-element {
  min-width: 21rem;
  text-align: left;
}

Zusammengesetzte Eigenschaften

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

Syntax

css
/* Column width */
columns: 18em;

/* Column count */
columns: auto;
columns: 2;

/* Column width and count */
columns: 2 auto;
columns: auto 12em;
columns: auto auto;

/* Column width and/or count, and column height */
columns: 18em / 10em;
columns: 2 / 90vh;
columns: 2 auto / 300px;

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

Der Wert der columns-Eigenschaft kann als <column-count> und/oder als <column-width>-Wert angegeben werden, in beliebiger Reihenfolge, optional gefolgt von einem <column-height>-Wert, der durch einen Schrägstrich (/) vorangestellt ist.

Werte

<'column-width'>

Die ideale Spaltenbreite, definiert als <length> oder das Schlüsselwort auto. Die tatsächliche Breite kann breiter oder schmaler sein, um den verfügbaren Platz zu füllen. Siehe column-width.

<'column-count'>

Die ideale Anzahl der Spalten, in die der Inhalt des Elements fließen sollte, definiert als <integer> oder das Schlüsselwort auto. Wenn sie als <integer> angegeben ist, definiert sie die maximal zulässige Anzahl von Spalten. Siehe column-count.

<'column-height'>

Die Höhe der Spalten, definiert als <length> oder das Schlüsselwort auto. Siehe column-height.

Hinweis: Das Setzen eines <column-height>-Werts setzt die column-wrap-Eigenschaft auf ihren Anfangswert auto zurück. Wenn <column-height> auf ein <length> gesetzt ist, wird der auto-Wert von column-wrap zu wrap. Wenn <column-height> auf auto gesetzt ist, wird es zu nowrap.

Formale Definition

Anfangswertwie die jeweiligen Kurzschreibweisen:
Anwendbar aufBlockcontainer außer Tabellen umgebende Boxen
VererbtNein
Berechneter Wertwie die jeweiligen Kurzschreibweisen:
Animationstypwie die jeweiligen Kurzschreibweisen:

Formale Syntax

columns = 
[ <'column-width'> || <'column-count'> ] [ / <'column-height'> ]?

<column-width> =
auto |
<length [0,∞]> |
min-content |
max-content |
fit-content( <length-percentage> )

<column-count> =
auto |
<integer [1,∞]>

<column-height> =
auto |
<length [0,∞]>

<length-percentage> =
<length> |
<percentage>

<integer> =
<number-token>

Beispiele

Drei gleiche Spalten einstellen

Dieses Beispiel zeigt, wie ein Textcontainer in drei gleiche Spalten aufgeteilt wird.

HTML

Wir fügen ein einfaches <p>-Element mit Textinhalt ein.

html
<p class="content-box">
  This is a bunch of text split into three columns using the CSS
  <code>columns</code>
  property. The text is equally distributed over the columns.
</p>

CSS

Wir setzen einen columns-Eigenschaftswert auf den Absatz, der einen <column-count>-Wert von 3 und einen <column-width>-Wert von auto enthält.

css
.content-box {
  columns: 3 auto;
}

Ergebnis

Beachten Sie, wie der Text in drei Spalten aufgeteilt wird.

Erstellen von Zeilenumbruch, feste Höhen-Spalten

Dieses Beispiel demonstriert die Verwendung eines <column-height>-Werts mit der columns-Kurzform-Eigenschaft, um einen Textcontainer in festhöhe Spalten aufzuteilen, die in neue Zeilen umgebrochen werden, wenn der Container den Inline-Rand erreicht.

HTML

Wir fügen ein einfaches <p>-Element mit etwas Text ein.

html
<p class="content-box">
  This is a bunch of text split into three columns using the CSS
  <code>columns</code> property. This includes a <code>column-count</code> value
  of <code>3</code>, a <code>column-width</code> value of <code>auto</code>, and
  a <code>column-height</code> value of <code>5em</code>. The
  <code>column-wrap</code> value is set to its initial value, <code>auto</code>;
  when a <code>column-height</code> value is included,
  <code>column-wrap: auto</code> resolves to <code>wrap</code>, which allows the
  columns to wrap onto multiple rows. The text is equally distributed over the
  columns, and placed into multiple rows.
</p>

CSS

Wir setzen einen columns-Eigenschaftswert auf den Absatz, der einen <column-count>-Wert von 3, einen <column-width>-Wert von auto und einen <column-height>-Wert von 5em enthält. Weil <column-height> auf ein <length> gesetzt ist, berechnet sich der column-wrap-Wert des Absatzes zu wrap, was es den Spalten ermöglicht, sich auf mehrere Zeilen zu erstrecken.

css
.content-box {
  columns: 3 auto / 5em;
}

Ergebnis

Beachten Sie, wie der Text in drei Spalten aufgeteilt wird. Jede Spalte ist 5em hoch. Nach jeder dritten Spalte brechen die Spalten in eine neue Zeile in Blockrichtung um.

Spezifikationen

Specification
CSS Multi-column Layout Module Level 2
# propdef-columns

Browser-Kompatibilität

Siehe auch