suchen

ONCSS

Jan 05, 2025 am 03:04 AM

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

ONCSS Naxrul Ahmed
ONCSS Naxrul Ahmed
GitHub Profile
npm Profile
Open Source Projects
GitHub-Profil npm-Profil

Open-Source-Projekte

⚡️ Wo Sie mich findenONCSS ONCSSONCSS ONCSS ONCSS

Das obige ist der detaillierte Inhalt vonONCSS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Orbitalmechanik (oder wie ich eine CSS -Keyframes -Animation optimiert habe)Orbitalmechanik (oder wie ich eine CSS -Keyframes -Animation optimiert habe)May 09, 2025 am 09:57 AM

Wie sieht es aus, Ihren eigenen Code neu zu gestalten? John Rhea nimmt eine alte CSS -Animation auseinander, die er geschrieben hat, und geht durch den Denkprozess der Optimierung.

CSS -Animationen: Ist es schwierig, sie zu erstellen?CSS -Animationen: Ist es schwierig, sie zu erstellen?May 09, 2025 am 12:03 AM

CsSanimationsarenotinherenthardbutRequirePractICEANDUnDing-fordertofcsPropertiesandTimingfunktionen.1) StartwithsimpleanimationslikescalingabuttononoversKeyFrames.2) useaSingFunctionslikecubic-BezierForteffects, SuchasabouNects, SuchasabouNects,, zu

@Keyframes CSS: Die am häufigsten verwendeten Tricks@Keyframes CSS: Die am häufigsten verwendeten TricksMay 08, 2025 am 12:13 AM

@KeyFramesispopulardUeToitSverSatility und PowerIncreatingsmoothcsSanimations.KectrickSinclude: 1) DefiningsmoothTransitionSbetTates, 2) AnimatingMultipleProperTiesimultan, 3) mit VendorprefixesforBrowserCompatible, 4) Kombinieren, 4) Kombinieren, 4) Kombinieren, 4) Kombinieren, 4) Kombinieren

CSS -Zähler: Eine umfassende Anleitung zur automatischen NummerierungCSS -Zähler: Eine umfassende Anleitung zur automatischen NummerierungMay 07, 2025 pm 03:45 PM

CSSCOUSTERSSARUSTOMANAGEAUTOMATICNUMBERINGINWEBDEsigns.1) Sie konzipieren SieForsofcontents, ListItems und CustomNumbering.2) AdvanceduSesincnednumberingSystem.3) CHEFORDIGESINCLUDSERCOMPATIBILIBLEISE.4) CreativeuSinvolvecustInance

Moderne Bildlaufschatten mit scrollengetriebenen AnimationenModerne Bildlaufschatten mit scrollengetriebenen AnimationenMay 07, 2025 am 10:34 AM

Die Verwendung von Scroll -Schatten, insbesondere für mobile Geräte, ist ein subtiles Stück UX, das Chris zuvor abgedeckt hat. Geoff deckte einen neueren Ansatz ab, der die Immobilie der Animationszeit verwendet. Hier ist ein anderer Weg.

Überprüfung der BildkartenÜberprüfung der BildkartenMay 07, 2025 am 09:40 AM

Lassen Sie uns eine kurze Auffrischung durchlaufen. Bildkarten datieren bis zu HTML 3.2, wobei zuerst die serverseitigen Karten und dann die clientseitigen Karten klickbare Regionen über ein Bild mit Karten- und Bereichselementen definiert sind.

Stand der Entwickler: Eine Umfrage für jeden EntwicklerStand der Entwickler: Eine Umfrage für jeden EntwicklerMay 07, 2025 am 09:30 AM

Die Umfrage von State of Devs ist nun offen für die Teilnahme und deckt im Gegensatz zu früheren Umfragen alles außer Code ab: Karriere, Arbeitsplatz, aber auch Gesundheit, Hobbys und mehr. 

Was ist CSS Grid?Was ist CSS Grid?Apr 30, 2025 pm 03:21 PM

CSS Grid ist ein leistungsstarkes Tool zum Erstellen komplexer, reaktionsschneller Weblayouts. Es vereinfacht das Design, verbessert die Zugänglichkeit und bietet mehr Kontrolle als ältere Methoden.

See all articles

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ße Werkzeuge

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

mPDF

mPDF

mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools