Inhaltsverzeichnis
Themenübersicht
Treten Sie unserer Mailingliste bei
Verwenden Sie Rückenwind für Themendesign
Verwenden Sie benutzerdefinierte Eigenschaften für Themendesign
Legacy Browser behandeln
Postcss-Custom-Properties
IE11CustomProperties
Aber was hat das mit Rückenwind zu tun?
Verwenden Sie Konfiguration als Style -Handbuch
Zusammenfassen
Heim Web-Frontend CSS-Tutorial Farbthemen mit CSS -benutzerdefinierten Eigenschaften und Rückenwind

Farbthemen mit CSS -benutzerdefinierten Eigenschaften und Rückenwind

Apr 01, 2025 am 04:58 AM

Farbthemen mit CSS -benutzerdefinierten Eigenschaften und Rückenwind

CSS -benutzerdefinierte Eigenschaften verbessern nicht nur die Code -Effizienz, sondern schaffen auch mehr Möglichkeiten in CSS, insbesondere im Themendesign. Das Atomic Smash -Team verwendet Rückenwind -CSS (ein Rahmen der Utility -Klasse). In diesem Artikel wird untersucht, wie benutzerdefinierte Eigenschaften für das Themendesign verwendet werden und wie Sie ihn in den Tailwind integrieren, um die Wiederverwendbarkeit Ihres Codes zu maximieren. In diesem Artikel wird die Einführung in den Rückenwind nicht erläutert. Bitte überprüfen Sie die offizielle Dokumentation. Selbst wenn Sie neu im Rückenwind sind, finden Sie möglicherweise einige Tipps nützlich.

Themenübersicht

Angenommen, wir haben eine "CTA" -Komponente, die Titel, Körper und Schaltflächen enthält.

Das Schreiben eines regulären CSS (Nicht-Schwanzwind) für dieses Farbschema sieht Folgendes aus:

 <code>.cta { background-color: #742a2a; // 深红色 color: #ffffff; // 白色}  .cta__heading { background-color: #e53e3e; // 中等红色 color: #742a2a; } .cta__button { background-color: #e53e3e; }</code>
Nach dem Login kopieren

Mit Rückenwind werden wir diese Farben als Dienstprogrammklassen in HTML anwenden:

<code><div>
<h3 id="Treten-Sie-unserer-Mailingliste-bei">Treten Sie unserer Mailingliste bei</h3>
<div>
<p>Lassen Sie die Ersten unsere neuen Produkte kennenlernen</p>
  registrieren</div>
</div></code>
Nach dem Login kopieren

Ich habe absichtlich Klassen ausgelassen, die nicht mit dem Grundfarbschema zusammenhängen, aber Sie können das vollständige Beispiel in dieser Demo sehen:

Wenn wir nun ein anderes Farbschema auf unsere Komponente anwenden möchten, müssen wir den Farbwert der ursprünglichen Komponente überschreiben. In Ermangelung von Rückenwind besteht ein gemeinsamer Ansatz darin, die Themenklasse selbst an die Komponente selbst zu befestigen und den Farbwert in der Kaskade neu zu definieren. Für Komponenten mit der Modifikatorklasse ".CTA-Blue" (unter Verwendung der BEM Convention) werden wir den CSS-Wert des blauen Farbschemas anwenden:

 <code>.cta--blue { background-color: #2a4365; // 深蓝色} .cta--blue .cta__heading { background-color: #3182ce; // 中等蓝色 color: #2a4365; } .cta--blue .cta__button { background-color: #3182ce; }</code>
Nach dem Login kopieren

Wenn wir SASS oder andere Präprozessoren verwenden, können wir Variablen verwenden, um unsere Arbeit zu vereinfachen, und wir können .CTA__ -Heading und .CTA__Body -Selektoren nisten. Es macht unseren Code nicht prägnanter, aber durch Aktualisierung dieser Werte an einem Ort wird der Code besser verwaltbar.

Angenommen, wir haben 10 verschiedene Farbschemata, wie ich in letzter Zeit in einem Projekt erlebt habe. Unser Code beginnt länger, da wir das obige Beispiel 10 -mal im Grunde wiederholt haben, bevor wir diese Farbwerte ändern. Stellen Sie sich nun vor, dass jede Komponente in unserem Designsystem 10 Farbschemata benötigt und viele Komponenten viel komplexer sind als unser einfaches CTA. Vielleicht braucht unser Thema auch unterschiedliche Schriftarten. Plötzlich müssen wir viele CSS schreiben.

Verwenden Sie Rückenwind für Themendesign

Auf der anderen Seite müssen wir, wenn wir Rückenwind verwenden, mehrere Klassen in der HTML selbst ändern. Auch wenn wir JavaScript -Frameworks (wie React oder Vue) verwenden, ist dies keine leichte Aufgabe. Um sicherzustellen, dass unbenutzte Stile in Produktionsversionen entfernt werden, entmutigt Rückenwind die Verwendung von String -Verkettung, um Klassennamen (zum Zeitpunkt des Schreibens) zu erstellen. Das Aufbau unserer Themen bedeuten daher möglicherweise, unseren Komponenten viel Logik hinzuzufügen.

Verwenden Sie benutzerdefinierte Eigenschaften für Themendesign

Durch die Verwendung benutzerdefinierter Eigenschaften für unsere Farbthemen können wir die Menge an Code, die geschrieben werden muss, drastisch reduzieren und die Wartungsbelastung reduzieren. Schauen wir uns zunächst an, wie das in regulärem CSS geht.

Wir definieren das benutzerdefinierte Attribut als: eine Variable auf dem Stammauswahl, was es zu einer globalen Variablen macht. (Der Körperwahlkörper gilt auch.) Wir können diese Variablen dann verwenden, um den Farbattributwert im Selektor zu ersetzen:

 <code>:root { --primary: #742a2a; // 深红色 --secondary: #e53e3e; // 中等红色} .cta { background-color: var(--primary); color: white; } .cta__heading { background-color: var(--secondary); color: var(--primary); } .cta__button { background-color: var(--secondary); }</code>
Nach dem Login kopieren

Hier ist es wirklich magisch: Erstellen Sie nun Code für jedes Thema, erfordert nur die Aktualisierung dieser benutzerdefinierten Attributwerte. Egal wo wir die Themenklasse anwenden, der neue Wert wird vererbt:

 <code>.th-blue { --primary: #2a4365; // 深蓝色 --secondary: #3182ce; // 中等蓝色}</code>
Nach dem Login kopieren

Wenn wir ein blaues Farbschema wollen, können wir die .Th-Blue-Klasse auf die Komponente anwenden und sogar in Verwenden Sie es auf dem Tag, um das Seitenthema anzuwenden, und überschreiben Sie es dann bei Bedarf auf einzelnen Komponenten. Die Verwendung von Dienstprogrammklassen kann uns mehr des Codes-Schreibaufwands sparen als Komponenten-spezifische Klassen (wie .CTA-Blue im Originalcode), da er überall in unserer Codebasis angewendet werden kann.

Legacy Browser behandeln

Wie viele Agenturen benötigen viele Atomic Smash -Kunden immer noch unsere Unterstützung für Internet Explorer 11. Während ich in den meisten Fällen progressive Verbesserungsmethoden akzeptieren kann (z. B. ein einfacheres Fallback -Layout für Browser, die CSS -Raster nicht unterstützen), fand ich das Design -Design, der normalerweise keine einfachen Kompromisse zulässt. Kunden möchten ihre Markenfarben und Schriftarten auch in älteren Browsern sehen. Die Bereitstellung eines Fallbacks mit einer Feature -Abfrage erfordert viel zusätzliche Arbeit, wodurch die Vorteile der Verwendung benutzerdefinierter Eigenschaften ausgleichen. Um dieses Problem zu überwinden, brauchen wir eine Polyfill.

Es gibt verschiedene Optionen, um Polyfill für benutzerdefinierte Eigenschaften im IE 11 bereitzustellen.

Postcss-Custom-Properties

Die erste besteht darin, ein Postcss-Plugin namens POSSS-Custom-ProPerties zu verwenden. Wenn Sie bereits Postcss in Ihrem Workflow verwenden, ist das Hinzufügen dieses Plugins ziemlich einfach. Es funktioniert, indem Sie Ihr CSS verarbeiten und das Ergebnis der Variablen als Eigenschaftswerte ausgeben. Also, wenn Sie das folgende CSS haben:

 <code>:root { --color: red; } h1 { color: var(--color); }</code>
Nach dem Login kopieren

Das Ergebnis nach der Verarbeitung wird:

 <code>h1 { color: red; color: var(--color); }</code>
Nach dem Login kopieren

Browser, die keine benutzerdefinierten Eigenschaften unterstützen, ignorieren die zweite Regel und greifen auf den regulären Immobilienwert zurück. Es besteht auch die Möglichkeit, Regeln mit benutzerdefinierten Eigenschaften aus der Ausgabe zu entfernen, sodass die Dateigröße kleiner ist. Dies bedeutet, dass kein Browser benutzerdefinierte Eigenschaften erhält - es ist ein Problem, wenn Sie Variablen dynamisch aktualisieren -, aber Sie können sie für statische Werte in Ihrem Code ohne nachteilige Auswirkungen verwenden.

Leider hat diese Polyfill einige Einschränkungen:

  1. Sie müssen eine Datei (oder Datei) angeben, die benutzerdefinierte Eigenschaften in der Konfiguration definiert.
  2. Benutzerdefinierte Eigenschaften können nur auf dem Root -Selektor definiert werden.

Die erste Grenze ist relativ trivial, aber die zweite macht diese Polyfonie leider völlig nutzlos für unsere Anwendungsfälle für Themen Design. Dies bedeutet, dass wir Variablen im Selektor nicht neu definieren können, um unser Thema zu erstellen.

IE11CustomProperties

Diese Polyfill -Option umfasst die Bereitstellung von Client -Skripten anstelle der Vorverarbeitung CSS. Wir können unserem Kopf das folgende Skript hinzufügen, um sicherzustellen, dass Polyfill nur in IE 11 geladen wird:

 <code>window.MSInputMethodContext && document.documentMode && document.write('');</code>
Nach dem Login kopieren

Dies ermöglicht es uns, die benutzerdefinierten Eigenschaften wie im Beispiel hier zu nutzen. Dies ist also die Lösung, für die ich mich entschieden habe. Es hat eine Einschränkung, dass benutzerdefinierte Eigenschaften, die im Style -Attribut festgelegt sind, nicht polyfillt werden. Aber ich habe es an dem obigen Beispiel für Themendesign getestet und es funktioniert einwandfrei.

Aber was hat das mit Rückenwind zu tun?

Wie wir gesehen haben, können Utility-Kurse-einzwecke Klassen, die überall in HTML angewendet werden können-unseren Code wiederverwendbarer machen. Dies ist das Hauptverkaufsargument von Rückenwind und anderen Rahmenbedingungen für Utility -Klassen - die Größe der von Ihnen lieferenden CSS -Datei wird infolgedessen schließlich kleiner. Tailwind bietet mehrere Farbkurse: .BG-rot-Medium bietet uns den roten Eigenschafts-Eigenschaftswert, .Text-red-medium ist für Farbe usw. für Rand, Box-Shadow oder überall, wo Sie sich vorstellen können, wo Farbwerte benötigt werden können.

Farben können in der Konfigurationsdatei definiert werden:

 <code>module.exports = { theme: {  colors: {   red: {    medium: '#e53e3e',    dark: '#742a2a'   },   blue: {    medium: '#3182ce',    dark: '#2a4365'   }  } } }</code>
Nach dem Login kopieren

Wenn wir benutzerdefinierte Eigenschaftswerte für unsere Rückenwindklasse verwenden möchten, können wir diese in der Konfiguration angeben:

 <code>module.exports = { theme: {  colors: {   'th-primary': 'var(--primary)',   'th-secondary': 'var(--secondary)'  } } }</code>
Nach dem Login kopieren

Ich habe die Namen der Fachklassen vorangestellt, sodass es offensichtlich ist, dass sie für das Subjektdesign besonders relevant sind. Sie können jedoch gerne jede Konvention verwenden, die zu Ihnen passt.

Jetzt können wir diese Klassen durch Rückenwind verwenden. Die Verwendung von .bg-Th-Primary entspricht dem Schreiben:

 <code>.some-element { background-color: var(--primary); }</code>
Nach dem Login kopieren

In unserem CSS können wir benutzerdefinierte Eigenschaften des Themas wie zuvor definieren:

 <code>:root { --primary: #742a2a; --secondary: #742a2a; } .th-blue { --primary: #2a4365; --secondary: #3182ce; }</code>
Nach dem Login kopieren

Wenden wir diese Klassen auf unsere HTML an. Das erste Beispiel bietet uns eine Komponente mit einem Standardthema (Variablen definiert auf: root). Der zweite hat unser blaues Thema. Der einzige Unterschied besteht darin, dass der Komponente der. Die blaue Klasse hinzugefügt wurde. (Einfachheit und Klarheit habe ich Klassen weggelassen, die nicht mit dem Thema zusammenhängen.)

<code><div class="bg-th-primary text-white">
<h3 id="Treten-Sie-unserer-Mailingliste-bei">Treten Sie unserer Mailingliste bei</h3>
<div>
<p>Lassen Sie die Ersten unsere neuen Produkte kennenlernen</p>
<button class="bg-th-secondary">registrieren</button>
</div>
</div>


<div class="th-blue bg-th-primary text-white">
<h3 id="Treten-Sie-unserer-Mailingliste-bei">Treten Sie unserer Mailingliste bei</h3>
<div>
<p>Lassen Sie die Ersten unsere neuen Produkte kennenlernen</p>
<button class="bg-th-secondary">registrieren</button>
</div>
</div></code>
Nach dem Login kopieren

Verwenden Sie Konfiguration als Style -Handbuch

Tailwind ermutigt Sie, alle Variablen in Ihrer Konfiguration zu definieren, und persönlich stimme ich zu, dass dies ein besserer Ansatz ist. Dies bedeutet, dass die Konfigurationsdatei eher eine einzige Quelle der Tatsachenquelle sein kann, anstatt (wahrscheinlich) mit mehreren Orten, um die Farbe und andere Themenwerte zu definieren. Glücklicherweise können wir auch die Werte in der Tailwind -Konfigurationsdatei für unsere benutzerdefinierten Eigenschaften verwenden. Wir müssen zunächst alle Farben in der Konfiguration definieren (vorausgesetzt, wir verwenden nicht die Standardpalette, die von Rückenwind enthalten ist):

 <code>module.exports = { theme: {  colors: {   red: {    medium: '#e53e3e',    dark: '#742a2a'   },   blue: {    medium: '#3182ce',    dark: '#2a4365'   },   'th-primary': 'var(--primary)',   'th-secondary': 'var(--secondary)'  } } }</code>
Nach dem Login kopieren

Dann können wir in CSS auf das Themenobjekt zugreifen:

 <code>:root { --primary: theme('colors.red.dark'); --secondary: theme('colors.red.medium'); } .th-blue { --primary: theme('colors.blue.dark'); --secondary: theme('colors.blue.medium'); }</code>
Nach dem Login kopieren

Zusammenfassen

Ich freue mich sehr, benutzerdefinierte Eigenschaften zu verwenden, ohne mir Sorgen um den Browserunterstützung zu machen, und ich freue mich noch mehr, es nahtlos in unsere vorhandenen Workflows integrieren zu können. Es ist schwer, die Zeit zu übertreiben, die sie in Bezug auf das Themendesign retten werden. Ich hoffe, dass dieser Artikel Sie auch dann dazu ermutigen kann, benutzerdefinierte Eigenschaften für diesen Anwendungsfall zu versuchen, selbst wenn Sie kein Wirdwind -Benutzer sind.

Das obige ist der detaillierte Inhalt vonFarbthemen mit CSS -benutzerdefinierten Eigenschaften und Rückenwind. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
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
1666
14
PHP-Tutorial
1273
29
C#-Tutorial
1253
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

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:

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

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

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

See all articles