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

View in English Always switch to English

container-name CSS property

Baseline Weitgehend verfügbar

Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Februar 2023 browserübergreifend verfügbar.

Die container-name CSS-Eigenschaft gibt eine Liste von Abfragenamen für Container an, die von der @container At-Regel in einer Container-Abfrage verwendet werden.

Syntax

css
container-name: none;

/* A single name */
container-name: my-layout;

/* Multiple names */
container-name: my-page-layout my-component-library;

/* Global Values */
container-name: inherit;
container-name: initial;
container-name: revert;
container-name: revert-layer;
container-name: unset;

Werte

none

Der Standardwert. Der Abfragecontainer hat keinen Namen.

<custom-ident>

Eine groß-/klein-schreibungssensitive Zeichenkette, die zur Identifizierung des Containers verwendet wird. Die folgenden Bedingungen gelten:

  • Der Name darf nicht or, and, not oder default sein.
  • Der Namewert darf nicht in Anführungszeichen stehen.
  • Die gestrichelte Identität, die zur Angabe von benutzerdefinierten Bezeichnern verwendet wird (z. B. --container-name), ist zulässig.
  • Eine Liste von mehreren, durch Leerzeichen getrennten Namen ist erlaubt.

Formale Definition

Anfangswertnone
Anwendbar aufalle Elemente
VererbtNein
Berechneter Wertnone or an ordered list of identifiers
AnimationstypNot animatable

Formale Syntax

container-name = 
none |
<custom-ident>+

Beschreibung

Wenn kein Name angegeben ist, wird eine Container-Abfrage Stile auf Elemente basierend auf Attributen wie der Größe oder dem Scroll-Zustand des nächsten Vorfahren mit einem Containment-Kontext anwenden.

Hinweis: Die Nachkommen von Größencontainern können mit Größeneinheiten für Containerabfragen dimensioniert werden.

Wenn einem Containment-Kontext ein Name gegeben wird, kann er gezielt angesprochen werden, indem dieser Name in einer @container At-Regel gesetzt wird.

Es ist möglich, einen Abfragecontainer zu erstellen, indem einem Element ein container-name zugewiesen wird, und dann nur die Existenz dieses Namens in der zugehörigen @container At-Regel abgefragt wird, ohne eine Abfrageausdruck zu spezifizieren. Diese sogenannten name-only container queries ermöglichen es, selektiv Stile auf Elemente anzuwenden, basierend nur darauf, ob sie einen Vorfahren mit einem spezifischen container-name gesetzt haben.

Beispiele

Verwendung eines Containernamens

Angenommen, wir haben das folgende HTML-Beispiel, das eine Kartenkomponente mit einem Titel und etwas Text ist:

html
<div class="card">
  <div class="post-meta">
    <h2>Card title</h2>
    <p>My post details.</p>
  </div>
  <div class="post-excerpt">
    <p>
      A preview of my <a href="https://example.com">blog post</a> about cats.
    </p>
  </div>
</div>

Um einen Containment-Kontext zu erstellen, fügen Sie die container-type-Eigenschaft zu einem Element in CSS hinzu. Das folgende Beispiel erstellt zwei Containment-Kontexte, einen für die Meta-Informationen der Karte und einen für den Beitrag-Auszug:

Hinweis: Eine verkürzte Syntax für diese Deklarationen wird auf der container Seite beschrieben.

css
.post-meta {
  container-type: inline-size;
}

.post-excerpt {
  container-type: inline-size;
  container-name: excerpt;
}

Das Schreiben einer Container-Abfrage über die @container At-Regel wird Stile auf die Elemente des Containers anwenden, wenn die Abfrage wahr ist. Das folgende Beispiel hat zwei Container-Abfragen, eine, die nur auf die Inhalte des .post-excerpt-Elements angewendet wird und eine, die sowohl auf die .post-meta als auch auf die .post-excerpt-Inhalte angewendet wird:

css
@container excerpt (width >= 400px) {
  p {
    visibility: hidden;
  }
}

@container (width >= 400px) {
  p {
    font-size: 2rem;
  }
}

Für weitere Informationen zum Schreiben von Container-Abfragen siehe die Seite CSS Container Queries.

Verwendung mehrerer Containernamen

Sie können auch mehrere Namen für einen Container-Kontext durch ein Leerzeichen getrennt angeben:

css
.post-meta {
  container-type: inline-size;
  container-name: meta card;
}

Dadurch können Sie den Container mit einem der Namen in der @container At-Regel ansprechen. Dies ist nützlich, wenn Sie denselben Container mit mehreren Container-Abfragen ansprechen möchten, bei denen entweder Bedingung zutreffen könnte:

css
@container meta (width <= 500px) {
  p {
    visibility: hidden;
  }
}

@container card (width <= 200px) {
  h2 {
    font-size: 1.5em;
  }
}

Verwendung einer name-only Container-Abfrage

Dieses Beispiel zeigt, wie eine name-only container query verwendet wird.

HTML

Wir fügen ein <div> mit einer id von container ein und drei <p>-Elemente, von denen zwei im Container und eins außerhalb des Containers sind:

html
<div id="container">
  <p>I'm in the container.</p>
  <p>I'm also in the container.</p>
</div>
<p>I'm not in the container.</p>

CSS

Wir weisen dem Container einen Namen zu:

css
#container {
  container-name: my-container;
}

Wir können dann Stile selektiv nur auf die Elemente innerhalb der Container mit diesem Namenssatz anwenden, wie im nächsten Schnipsel gezeigt.

css
@container my-container {
  p {
    background-color: lime;
    font-size: 1.3rem;
    width: 50vw;
    padding: 0.5rem;
    font-family: sans-serif;
  }
}

Ergebnis

Die angegebenen Stile sollten nur auf das erste und zweite <p>-Element angewendet werden, nicht aber auf das dritte.

Spezifikationen

Spezifikation
CSS Conditional Rules Module Level 5
# container-name

Browser-Kompatibilität

Siehe auch