Heim Web-Frontend CSS-Tutorial Gestalten Sie HTML und mit modernem CSS

Gestalten Sie HTML und mit modernem CSS

Jan 03, 2025 am 05:54 AM

Geschrieben von Rob O'Leary✏️

Die

und HTML-Elemente, die zusammenfassend als Offenlegungs-Widget bezeichnet werden, sind nicht einfach zu formatieren. Aufgrund der Einschränkungen erstellen Benutzer oft ihre eigene Version mit einer benutzerdefinierten Komponente. Mit der Weiterentwicklung von CSS sind diese Elemente jedoch einfacher anzupassen. In diesem Artikel beschreibe ich, wie Sie das Erscheinungsbild und Verhalten eines Offenlegungs-Widgets anpassen können.

Wie werden
und zusammenarbeiten?

ist ein HTML-Element, das ein Offenlegungs-Widget erstellt, in dem zusätzliche Informationen ausgeblendet sind. Ein Offenlegungs-Widget wird normalerweise als dreieckige Markierung mit etwas Text dargestellt.

Wenn der Benutzer auf das Widget klickt oder sich darauf konzentriert und die Leertaste drückt, wird es geöffnet und zeigt zusätzliche Informationen an. Die Dreiecksmarkierung zeigt nach unten, um anzuzeigen, dass es sich im geöffneten Zustand befindet:

Styling HTML <details> und <summary> mit modernem CSS“ /></p>

<p><img src=

Wie funktioniert die Offenlegungsanimation?

Zuerst fügen wir interpolate-size hinzu, damit wir zu einer Höhe von auto: übergehen können

<details>
  <summary>Do you want to know more?</summary>
  <h3>Additional info</h3>
  <p>The average human head weighs around 10 to 11 pounds (approximately 4.5 to 5 kg).</p>
</details>
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Als nächstes wollen wir den geschlossenen Stil beschreiben. Wir möchten, dass der „Zusatzinfo“-Inhalt eine Höhe von Null hat und sicherstellen, dass kein Inhalt sichtbar ist, d. h. wir möchten einen Überlauf verhindern.

Wir verwenden das Pseudoelement ::details-content, um auf versteckte Inhalte zu zielen. Ich verwende die Blockgröße-Eigenschaft anstelle der Höhe, da es eine gute Angewohnheit ist, logische Eigenschaften zu verwenden. Wir müssen content-visibility in den Übergang einbeziehen, da der Browser content-visibility:hiden für den Inhalt einstellt, wenn er sich im geschlossenen Zustand befindet – die Abschlussanimation funktioniert nicht, ohne ihn einzuschließen:

<details>
  <summary>Do you want to know more?</summary>
  <h3>Additional info</h3>
  <p>The average human head weighs around 10 to 11 pounds (approximately 4.5 to 5 kg).</p>
</details>
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Die Animation funktioniert immer noch nicht wie erwartet, da die Eigenschaft „Inhaltssichtbarkeit“ eine diskrete animierte Eigenschaft ist. Dies bedeutet, dass keine Interpolation erfolgt; Der Browser wechselt zwischen den beiden Werten, sodass der geänderte Inhalt während der gesamten Animationsdauer angezeigt wird. Wir wollen das nicht.

Wenn wir „transition-behavior:allow-discrete;“ einbeziehen, kehrt sich der Wert ganz am Ende der Animation um, sodass wir unseren allmählichen Übergang erhalten.

Außerdem kommt es zu einem Inhaltsüberlauf, indem wir die Blockgröße auf 0 setzen, wenn sich das Offenlegungs-Widget in einem Zwischenzustand befindet. Wir zeigen den größten Teil des Inhalts beim Öffnen an. Um dies zu verhindern, fügen wir overflow:hiden hinzu.

Zuletzt fügen wir den Stil für den offenen Zustand hinzu. Wir möchten, dass der Endzustand die Größe auto:
hat

details {
    interpolate-size: allow-keywords;
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Das sind die groben Striche. Wenn Sie eine ausführlichere Videoerklärung bevorzugen, sehen Sie sich die exemplarische Vorgehensweise von Kevin Powell an, um zu erfahren, wie Sie

und .

Gibt es beim Animieren eines Offenlegungs-Widgets weitere Überlegungen?

Das Offenlegungs-Widget kann horizontal wachsen, wenn der Inhalt „Zusätzliche Informationen“ breiter ist als die Inhalt. Dies kann zu einer unerwünschten Layoutverschiebung führen. In diesem Fall möchten Sie möglicherweise eine Breite für

festlegen.

Wie bei jeder Animation sollten Sie Benutzer berücksichtigen, die empfindlich auf Bewegungen reagieren. Sie können die Medienabfrage „Preferences-Reduced-Motion“ verwenden, um diesem Szenario gerecht zu werden:

/* closed state */
details::details-content {
  block-size: 0;

  transition: content-visibility, block-size;
  transition-duration: 750ms;

  transition-behavior: allow-discrete;
  overflow: hidden;
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Implementierung eines exklusiven
Gruppe (exklusives Akkordeon)

Ein häufiges UI-Muster ist eine Akkordeonkomponente. Es besteht aus einem Stapel von Offenlegungs-Widgets, die erweitert werden können, um ihren Inhalt anzuzeigen. Um dieses Muster zu implementieren, benötigen Sie lediglich mehrere aufeinanderfolgende

Elemente. Sie können sie so gestalten, dass sie visuell darauf hinweisen, dass sie zusammengehören:

/* open state */
details[open]::details-content {
  block-size: auto;
}
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Der Standardstil ist ziemlich einfach:

Styling HTML <details> und <summary> mit modernem CSS“ /> </p>

<p>Alle <Details> belegt eine eigene Zeile. Sie sind eng beieinander positioniert (ohne Rand oder Polsterung) und werden aufgrund ihrer Nähe als Gruppe wahrgenommen. Wenn Sie hervorheben möchten, dass sie gruppiert sind, können Sie einen Rahmen hinzufügen und ihnen dieselben Hintergrundstile zuweisen, wie im folgenden Beispiel gezeigt:</p>

<p><iframe height=

Eine Variation dieses Musters besteht darin, das Akkordeon exklusiv zu machen, sodass jeweils nur eines der Offenlegungs-Widgets geöffnet werden kann. Sobald einer geöffnet wird, schließt der Browser den anderen. Sie können exklusive Gruppen über das Namensattribut von

erstellen. Der gleiche Name bildet eine semantische Gruppe:

<details>
  <summary>Do you want to know more?</summary>
  <h3>Additional info</h3>
  <p>The average human head weighs around 10 to 11 pounds (approximately 4.5 to 5 kg).</p>
</details>
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Überlegen Sie vor der Verwendung exklusiver Akkordeons, ob dies für Benutzer hilfreich ist. Wenn Benutzer wahrscheinlich mehr Informationen nutzen möchten, müssen sie die Elemente häufig öffnen, was frustrierend sein kann.

Diese Funktion wird derzeit in allen modernen Browsern unterstützt, sodass Sie sie sofort verwenden können.

Gestaltung der Zusammenfassungsmarkierung

Ein Offenlegungs-Widget wird normalerweise mit einer kleinen dreieckigen Markierung daneben angezeigt. In diesem Abschnitt behandeln wir den Prozess der Gestaltung dieses Markers.

Die Markierung ist mit der verknüpft. Element. Das Hinzufügen des Pseudoelements [::marker](https://developer.mozilla.org/docs/Web/CSS/::marker) bedeutet, dass wir das Markierungsfeld direkt formatieren können. Allerdings beschränken wir uns auf einen kleinen Satz von CSS-Eigenschaften:

  • Alle Schriftarteigenschaften
  • Farbe
  • Leerzeichen
  • text-combine-upright, [unicode-bidi](https://developer.mozilla.org/en-US/docs/Web/CSS/unicode-bidi) und Richtungseigenschaften
  • Inhalt
  • Alle Animations- und Übergangseigenschaften

Wie bereits erwähnt, ähnelt einem [

  • ](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/li); Es unterstützt die Kurzschrifteigenschaft im Listenstil und ihre Langschrifteigenschaften. Auch wenn das vielleicht ein wenig wirr ist, lassen sich die Gestaltungsoptionen anhand einiger Beispiele leichter verstehen.

    Bevor wir uns mit Beispielen befassen, ein kurzes Wort zur Browserunterstützung. Zum Zeitpunkt des Verfassens dieses Artikels ist Safari der einzige große Browser, der das Formatieren des Markers nicht vollständig unterstützt:

    • Die Safari-Unterstützung ist derzeit auf die Gestaltung der Farb- und Schriftgrößeneigenschaften des ::marker-Pseudoelements beschränkt. Safari unterstützt das nicht standardmäßige Pseudoelement ::-webkit-details-marker
    • Safari unterstützt das Stylen der Eigenschaften im Listenstil überhaupt nicht. Siehe CanIUse als Referenz

    Ändern der Farbe und Größe einer Markierung

    Angenommen, wir wollten die Farbe der dreieckigen Markierung in Rot ändern und sie um 50 % vergrößern. Wir können Folgendes tun:

    details {
        interpolate-size: allow-keywords;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Styling HTML <details> und <summary> mit modernem CSS“ /> </p>

<p>Dies sollte in allen Browsern funktionieren. Hier ist das CodePen-Beispiel.</p><h4>
  
  
  Anpassen des Abstands der Markierung
</h4>

<p>Standardmäßig befindet sich die Markierung neben dem Textinhalt von <summary> und sie befinden sich im selben Begrenzungsrahmen. Die List-Style-Position ist auf inside gesetzt. Im geöffneten Zustand befindet sich die „Zusatzinformation“ direkt unter der Markierung. Vielleicht möchten Sie den Abstand und die Ausrichtung ändern: </p>

<p><img src=

    Ändern des Markierungstextes/-bildes

    Wenn Sie den Inhalt des Markers ändern möchten, können Sie die content-Eigenschaft des Pseudoelements ::marker verwenden. Basierend auf Ihren Vorlieben können Sie es auf Text einstellen. Für mein Beispiel habe ich das Reißverschluss-Mund-Emoji für den geschlossenen Zustand und das Offener-Mund-Emoji für den geöffneten Zustand verwendet:

    details {
        interpolate-size: allow-keywords;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Um ein Bild für die Markierung zu verwenden, können Sie die content-Eigenschaft des Pseudoelements ::marker oder die list-style-image-Eigenschaft von

    :
    verwenden

    /* closed state */
    details::details-content {
      block-size: 0;
    
      transition: content-visibility, block-size;
      transition-duration: 750ms;
    
      transition-behavior: allow-discrete;
      overflow: hidden;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Im folgenden Beispiel verwenden wir zwei Pfeilsymbole von Material Symbols für die Markierung. Der nach rechts zeigende Pfeil steht für den geschlossenen Zustand und der nach unten zeigende Pfeil für den offenen Zustand:

    Diese Beispiele funktionieren wie erwartet in Chrome und Firefox, Safari ignoriert die Stile jedoch. Sie können dies als eine schrittweise Verbesserung betrachten und damit Schluss machen. Wenn Sie jedoch in allen Browsern das gleiche Erscheinungsbild wünschen, können Sie die Markierung ausblenden und dann Ihr eigenes Bild als Ersatz hinzufügen. Das gibt Ihnen mehr Freiheit:

    /* open state */
    details[open]::details-content {
      block-size: auto;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Sie können den Status mithilfe eines neuen Markierungssymbols, beispielsweise eines Inline-Bilds oder über Pseudoelemente, visuell anzeigen. Die zeigt bereits (meistens) den Erweiterungs-/Reduzierungsstatus an. Wenn Sie also eine Inline-Grafik verwenden, sollte diese als dekorativ behandelt werden. Ein leeres Alt-Attribut bewirkt Folgendes:

    <details>
      <summary>Do you want to know more?</summary>
      <h3>Additional info</h3>
      <p>The average human head weighs around 10 to 11 pounds (approximately 4.5 to 5 kg).</p>
    </details>
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Wenn Sie möchten, können Sie die Markierung auch am Ende der positionieren:

    details {
        interpolate-size: allow-keywords;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Es ist jedoch wichtig zu beachten, dass das Ausblenden der Markierung bei Bildschirmleseprogrammen zu Problemen bei der Barrierefreiheit führt. Firefox, VoiceOver, JAWS und NVDA haben alle ein Problem mit der konsistenten Ankündigung des umgeschalteten Status des Offenlegungs-Widgets, wenn die Markierung entfernt wird. Leider ist der Stil an den Staat gebunden. Es ist besser, dies zu vermeiden.

    Gestalten Sie den Abschnitt „Zusätzliche Informationen“ von

    Vielleicht möchten Sie den Abschnitt „Zusätzliche Informationen“ des Offenlegungs-Widgets formatieren, ohne Stile in die zu verlieren. Da Sie eine variable Anzahl von Elementen in einem

    haben können, wäre es schön, eine Sammelregel zu haben:

    /* closed state */
    details::details-content {
      block-size: 0;
    
      transition: content-visibility, block-size;
      transition-duration: 750ms;
    
      transition-behavior: allow-discrete;
      overflow: hidden;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Mein Ziel ist es, die Element mit der Funktion :not(). Bedenken Sie jedoch, dass dies auf jedes Element und nicht auf den Inhalt als einzelnen Abschnitt abzielt!

    /* open state */
    details[open]::details-content {
      block-size: auto;
    }
    
    Nach dem Login kopieren
    Nach dem Login kopieren
    Nach dem Login kopieren

    Styling HTML <details> und <summary> mit modernem CSS“ /> </p>

<p>Alternativ können Sie das Pseudoelement ::details-content verwenden, das auf den gesamten Abschnitt abzielt. Aus diesem Grund möchten Sie dies zum Animieren der Öffnungs- und Schließzustandsübergänge verwenden:<br>
</p>

<pre class=>@media (prefers-reduced-motion) { /* styles to apply if a user's device settings are set to reduced motion */ details::details-content { transition-duration: 0.8s; /* slower speed */ } }

    Erklärung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
  • Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    Video Face Swap

    Video Face Swap

    Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

    Heißer Artikel

    <🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    Mandragora: Flüstern des Hexenbaum
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    Nordhold: Fusionssystem, erklärt
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

    Heiße Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    Heiße Themen

    Java-Tutorial
    1667
    14
    PHP-Tutorial
    1273
    29
    C#-Tutorial
    1255
    24
    Ein Vergleich statischer Formanbieter Ein Vergleich statischer Formanbieter Apr 16, 2025 am 11:20 AM

    Versuchen wir, hier einen Begriff zu prägen: "Statischer Formanbieter". Sie bringen Ihre HTML

    Ein Beweis für das Konzept, um Sass schneller zu machen Ein Beweis für das Konzept, um Sass schneller zu machen Apr 16, 2025 am 10:38 AM

    Zu Beginn eines neuen Projekts erfolgt die SASS -Zusammenstellung im Blinzeln eines Auges. Dies fühlt sich gut an, besonders wenn es mit Browsersync kombiniert ist, das nachlädt

    Wöchentliche Plattformnachrichten: HTML -Ladeattribut, die Haupt -ARIA -Spezifikationen und Wechsel von Iframe zu Shadow Dom Wöchentliche Plattformnachrichten: HTML -Ladeattribut, die Haupt -ARIA -Spezifikationen und Wechsel von Iframe zu Shadow Dom Apr 17, 2025 am 10:55 AM

    In der Zusammenfassung der Plattformnachrichten in dieser Woche stellt Chrome ein neues Attribut für das Laden, Zugänglichkeitspezifikationen für Webentwickler und die BBC -Bewegungen ein

    Einige praktisch mit dem HTML-Dialogelement Einige praktisch mit dem HTML-Dialogelement Apr 16, 2025 am 11:33 AM

    Ich schaue mir das HTML -Element zum ersten Mal an. Ich habe es für eine Weile dessen bewusst, aber Haven &#039; Es wurde es noch nicht für einen Dreh genommen. Es hat einige ziemlich cool und

    Papierform Papierform Apr 16, 2025 am 11:24 AM

    Buy or Build ist eine klassische Technologiedebatte. Das Aufbau von Dingen selbst ist vielleicht billiger, weil Ihre Kreditkartenrechnung keine Werbebuchung gibt, aber

    Wohin sollte 'Podcast' -Link abonnieren? Wohin sollte 'Podcast' -Link abonnieren? Apr 16, 2025 pm 12:04 PM

    Für eine Weile war iTunes der große Hund im Podcasting. Wenn Sie also "Abonnieren Sie Podcast" verlinkt haben, um zu mögen:

    Optionen zum Hosting Ihrer eigenen nicht-javaScript-basierten Analysen Optionen zum Hosting Ihrer eigenen nicht-javaScript-basierten Analysen Apr 15, 2025 am 11:09 AM

    Es gibt eine Menge Analyseplattformen, mit denen Sie Besucher- und Nutzungsdaten auf Ihren Websites verfolgen können. Vielleicht vor allem Google Analytics, das weit verbreitet ist

    Es ist alles in der Kopf Es ist alles in der Kopf Apr 15, 2025 am 11:01 AM

    Der Dokumentkopf ist vielleicht nicht der glamouröseste Teil einer Website, aber was darauf einfließt

    See all articles