oncss
oncss ist eine CSS-in-JS-Bibliothek, die Entwicklern eine leistungsstarke CSS-Funktion zum Gestalten ihrer Webanwendungen bietet. Es erm?glicht moderne Styling-Techniken, einschlie?lich verschachtelter Selektoren, responsivem Design und dynamischen Keyframes, und bietet gleichzeitig eine nahtlose Integration mit JavaScript-Frameworks wie React.
Installation
Installieren Sie das oncss-Paket über npm:
npm install oncss
Importieren Sie die CSS-Funktion in Ihr Projekt:
import css from 'oncss';
Kernkonzept: Die CSS-Funktion
Die CSS-Funktion ist das Herzstück von oncss und wurde entwickelt, um CSS dynamisch zu generieren und in Ihre Anwendung einzufügen. Es unterstützt:
- CSS-Eigenschaften: Standard-CSS-Eigenschaften und -Werte verwenden.
- Verschachtelte Selektoren: Wenden Sie Stile mit & auf untergeordnete Elemente oder Zust?nde an.
- Medienabfragen: Implementieren Sie responsive Designs mit @media-Regeln.
- Keyframes: Erstellen Sie Animationen mit @keyframes.
- Globale Stile: Wenden Sie Stile global mit @global an.
- Benutzerdefinierte Haltepunkte: Definieren Sie wiederverwendbare Haltepunkte für die Reaktionsf?higkeit.
- Andere At-Regeln: Nutzen Sie zus?tzliche At-Regeln wie @container, @layer und @supports.
Grundlegendes Beispiel
const buttonStyles = css({ backgroundColor: 'blue', color: 'white', padding: '10px 20px', borderRadius: '5px', '&:hover': { backgroundColor: 'darkblue', }, '@media (min-width: 768px)': { padding: '15px 30px', }, }); console.log(buttonStyles);
Konfigurationsoptionen
Die CSS-Funktion kann über ein Optionsobjekt angepasst werden:
Verfügbare Eigenschaften
Property | Type | Description |
---|---|---|
classPrefix | string | Adds a prefix to generated class names. |
breakpoints | object | Custom breakpoints for responsive designs. |
aliases | object | Custom shorthand properties for CSS rules. |
injectStyle | boolean | Controls whether styles are auto-injected. |
skipProps | function | Filters out unwanted properties. |
getValue | function | Transforms property values dynamically. |
getProps | function | Customizes specific property handling. |
Beispiel mit Optionen
npm install oncss
Verwenden von Haltepunkten
Sie k?nnen die definierten Haltepunkte in Ihren Stilen verwenden, um responsive Designs zu erstellen:
import css from 'oncss';
Reagieren Sie auf Integration
oncss l?sst sich nahtlos in React integrieren. übergeben Sie einfach den generierten Klassennamen an Ihre Komponente.
Reaktionsbeispiel
const buttonStyles = css({ backgroundColor: 'blue', color: 'white', padding: '10px 20px', borderRadius: '5px', '&:hover': { backgroundColor: 'darkblue', }, '@media (min-width: 768px)': { padding: '15px 30px', }, }); console.log(buttonStyles);
Erweiterte Funktionen
Verschachtelte Selektoren
Stile auf untergeordnete Elemente oder Pseudoklassen anwenden:
const styles = css({ fontSize: 16, padding: 10, }, { classPrefix: 'myprefix', breakpoints: { sm: 480, md: 768, lg: 1024, }, });
Medienanfragen
Fügen Sie ganz einfach responsive Stile hinzu:
const responsiveStyles = css({ fontSize: 14, padding: { sm: 12, lg: 24 }, }, { breakpoints: { sm: 480, md: 768, lg: 1024, }, });
Schlüsselbilder
Animationen definieren und verwenden:
import React from 'react'; import css from 'oncss'; const buttonStyle = css({ backgroundColor: 'green', color: 'white', padding: '10px 20px', borderRadius: '8px', '&:hover': { backgroundColor: 'darkgreen', }, }); function Button() { return <button classname="{buttonStyle.toString()}">Click Me</button>; } export default Button;
Globale Stile
Globale Stile mühelos anwenden:
const cardStyles = css({ padding: '20px', border: '1px solid #ccc', '& h1': { fontSize: '24px', margin: 0, }, '&:hover': { boxShadow: '0 4px 8px rgba(0, 0, 0, 0.1)', }, });
Unterstützte At-Regeln
oncss unterstützt verschiedene CSS-At-Regeln, um Ihre Styling-M?glichkeiten zu verbessern. Hier ist eine Liste der unterstützten At-Regeln mit Beschreibungen:
At-Rule | Description |
---|---|
@media | Used for applying styles based on media queries for responsive design. |
@keyframes | Defines animations that can be applied to elements. |
@global | Applies styles globally across the entire application. |
@container | Used for container queries to apply styles based on container size. |
@layer | Defines style layers to control the order of style application. |
@supports | Applies styles based on the support of specific CSS features in the browser. |
Serverseitiges Styling
oncss unterstützt serverseitiges Rendering (SSR) durch die Nutzung der CSSFactory zum Speichern und Verwalten generierter CSS-Stile. Dadurch k?nnen Sie Stile extrahieren und in Ihr vom Server gerendertes HTML einfügen.
Beispiel mit React
Hier ist ein Beispiel für die Verwendung von oncss für serverseitiges Rendering mit React:
npm install oncss
formatCSSValue
formatCSSValue ist eine Hilfsfunktion, die CSS-Werte formatiert und bei Bedarf Einheiten wie px hinzufügt.
import css from 'oncss';
TypeScript-Integration
oncss bietet vollst?ndige TypeScript-Unterstützung, sodass Sie Typen für Ihre CSS-Eigenschaften und -Optionen definieren k?nnen.
Definieren von CSS-Eigenschaften
Sie k?nnen die Typen für Ihre CSS-Eigenschaften mithilfe des CSSProps-Typs definieren:
const buttonStyles = css({ backgroundColor: 'blue', color: 'white', padding: '10px 20px', borderRadius: '5px', '&:hover': { backgroundColor: 'darkblue', }, '@media (min-width: 768px)': { padding: '15px 30px', }, }); console.log(buttonStyles);
Verwenden von Optionen mit Typen
Sie k?nnen auch Typen für das Optionsobjekt definieren:
const styles = css({ fontSize: 16, padding: 10, }, { classPrefix: 'myprefix', breakpoints: { sm: 480, md: 768, lg: 1024, }, });
Abschluss
oncss vereinfacht das Styling für moderne Webanwendungen. Sein robuster Funktionsumfang, vom responsiven Design bis hin zu Keyframe-Animationen, macht es zu einem unsch?tzbar wertvollen Werkzeug für Entwickler.
Autor

![]() |
Naxrul Ahmed GitHub Profile npm Profile Open Source Projects |
Open-Source-Projekte
?? Wo Sie mich finden
Das obige ist der detaillierte Inhalt vonONCSS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

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

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

CSS -Bl?cke Seitenrenderung, da Browser inline und externe CSS standardm??ig als wichtige Ressourcen anzeigen, insbesondere mit importierten Stylesheets, Header gro?er Mengen an Inline -CSS und nicht optimierten Medienfragestilen. 1. extrahieren kritische CSS und einbetten Sie es in HTML ein; 2. Verz?gerung des Ladens nichtkritischer CSS durch JavaScript; 3.. Verwenden Sie Medienattribute, um das Laden wie Druckstile zu optimieren. 4. Komprimieren und verschmelzen CSS, um Anfragen zu reduzieren. Es wird empfohlen, Tools zum Extrahieren von Schlüssel -CSS zu verwenden, REL = "Vorspannung" zu kombinieren, und verwenden Sie die asynchrone Belastung und verwenden Sie die Medienverz?gerungsladeverletzung, um eine überm??ige Aufteilung und eine komplexe Skriptsteuerung zu vermeiden.

ThebestApproachforcssDependsonTheProject'Sspecificneeds.forlargerProjects, externalcssisbetterDuetomaintainability;

Csssmostlycase-unempfindlich, buturlsandfontfamilynamesarecase-sensitiv.1) Eigenschaften und ValueslikeColor: rot; sensitiv.2) URLSMUTMATTHESERVER'SCASE, z.

AutoPrefixer ist ein Tool, das die Pr?fixe von Anbietern automatisch zu CSS -Attributen basierend auf dem Zielbrowserbereich hinzufügt. 1. Es l?st das Problem, die Pr?fixe mit Fehlern manuell aufrechtzuerhalten. 2. Arbeiten Sie das POSTCSS-Plug-in-Formular durch, analysieren Sie CSS, analysieren Sie Attribute, die vorangestellt werden müssen, und generieren Sie den Code gem?? Konfiguration. 3.. 4. Notizen enthalten nicht manuelles Hinzufügen von Pr?fixen, Konfigurationsaktualisierungen, Pr?fixe nicht alle Attribute, und es wird empfohlen, sie mit dem Pr?prozessor zu verwenden.

CSSCOUNTERSCANATOMATIONSNUMBERSEctions und.1) usecounter-resettoinitialize, counter-IncrementtoIncrease, und Counter () orcounters () todisplayValues.2) kombinierte withjavascriptfordynamiccontentToEsSureAccurateupdates.

In CSS sind Selektor- und Attributnamen fallempfindlich, w?hrend Werte, Namen, URLs und benutzerdefinierte Attribute fallempfindlich sind. 1. Die Auswahl- und Attributnamen sind unempfindlich, z. B. Hintergrundfarbe und Hintergrundfarbe sind gleich. 2. Die hexadezimale Farbe im Wert ist fallempfindlich, aber die benannte Farbe ist fallempfindlich, wie rot und rot ist ungültig. 3. Die URLs sind fallsempfindlich und k?nnen zu Ladeproblemen von Dateien führen. 4. Benutzerdefinierte Eigenschaften (Variablen) sind fallempfindlich und Sie müssen auf die Konsistenz des Falles bei der Verwendung achten.

CsSelectorsandPropertyNamesArecase-inemsitiv, w?hrend Valuescanbecase-sensibiledPendingoncontext.1) Selectors wie div'and'div'areequivalent.2) PropertieSuchas'back-background-color'and'background-Color'arteated-theam.3) VactieLKasecasecasecasecasecase-Ensens
