Heim > Web-Frontend > CSS-Tutorial > Wie kann ich Sass-Farbvariablen basierend auf HTML-Elementklassen dynamisch festlegen?

Wie kann ich Sass-Farbvariablen basierend auf HTML-Elementklassen dynamisch festlegen?

Mary-Kate Olsen
Freigeben: 2024-10-28 05:31:02
Original
266 Leute haben es durchsucht

How can I dynamically set Sass color variables based on HTML element classes?

Konfigurieren dynamischer Sass-Variablen basierend auf HTML-Elementklassen

Frage: Kann ich Sass-Farbvariablen basierend auf Klassen, die auf ein HTML-Element angewendet werden, dynamisch festlegen? ?

Antwort: Ja, Sie können dies durch die Verwendung von Sass-Includes oder -Mixins erreichen.

Verwendung von Includes

In einer separaten Datei (_theme .scss), definieren Sie die Stile mithilfe Ihrer Sass-Variablen:

<code class="scss">section.accent {
    background: $accent;
}

.foo {
    border: $base;
}

.bar {
    color: $flat;
}</code>
Nach dem Login kopieren

In Ihrer Haupt-Sass-Datei (main.scss) importieren Sie das Include basierend auf der Klasse im HTML-Element:

<code class="scss">html {
  &amp;.sunrise {
    $accent: #37CCBD;
    $base: #3E4653;
    $flat: #eceef1;

    @import "theme";
  }

  &amp;.moonlight {
    $accent: #18c;
    $base: #2a2a2a;
    $flat: #f0f0f0;

    @import "theme";
 }
}</code>
Nach dem Login kopieren

Mixins verwenden

Alternativ können Sie ein Mixin erstellen, das die Farben als Argumente verwendet:

<code class="scss">@mixin theme($accent, $base, $flat) {
    // Define styles using the passed variables
}</code>
Nach dem Login kopieren

In Ihrer Haupt-Sass-Datei rufen Sie das Mixin mit den entsprechenden Farben auf:

<code class="scss">html {
  &amp;.sunrise {
    $accent: #37CCBD;
    $base: #3E4653;
    $flat: #eceef1;

    @include theme($accent, $base, $flat);
  }

  &amp;.moonlight {
    $accent: #18c;
    $base: #2a2a2a;
    $flat: #f0f0f0;

    @include theme($accent, $base, $flat);
 }
}</code>
Nach dem Login kopieren

Dieser Ansatz ermöglicht es Ihnen, verschiedene Themen basierend auf ihren Klassen dynamisch auf HTML-Elemente anzuwenden.

Das obige ist der detaillierte Inhalt vonWie kann ich Sass-Farbvariablen basierend auf HTML-Elementklassen dynamisch festlegen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage