suchen
HeimWeb-FrontendHTML-TutorialSo implementieren Sie die dynamische Bindung von Klasse und Stil in React-JSX (mit Beispielen)

Der Inhalt dieses Artikels befasst sich mit der Implementierung der dynamischen Bindung von Klasse und Stil in React-JSX (mit Beispielen). Ich hoffe, dass er für Sie hilfreich ist . hat geholfen.

Zusammenfassung: Die Manipulation von Klassenlisten und Inline-Stilen von Elementen ist eine häufige Anforderung für die Datenbindung. Um eine leistungsstarke JS zu erreichen, ist eine dynamische Bindung von Klassen und Stilen erforderlich ein hohes Maß an Lese- und Schreibkenntnissen. Dieser Artikel basiert auf der React-JSX-Syntax und wird mit den Implementierungsmethoden anderer Frameworks kombiniert, um vorzustellen, wie die dynamische Bindung von ClassName und Style implementiert wird.

Hinweis: Die Beispiele in diesem Artikel wurden überprüft. Bitte kritisieren und korrigieren Sie sie.

HTML-Klasse binden

Objektsyntax

Wir können „Give className“ an ein Objekt übergeben, um Klassen dynamisch zu wechseln:

Hinweis: Die Verwendung von Objektsyntax wie Vue, Applet usw. wird nicht unterstützt

Fehlerbeispiel:

render(){
  return <p>hello world</p>
}

kann erreicht werden. Die Syntax lautet wie folgt:

1. Verwenden Sie logische Operatoren

CSS-Datei

.box-color {
  color:red;
}

js-Datei

render(){
  return <p>hello world</p>
}
2. Verwenden Sie den ternären Operator

CSS-Datei

.box-show {
  display: block;
}

.box-hide {
  display: none;
}
render(){
  return <p>hello world</p>
}
3. Mit Funktionen

gebundene Datenobjekte müssen nicht inline in der Vorlage definiert werden: Sie können eine Funktion definieren, ähnlich der berechneten Hook-Funktion in vue

js-Datei

getIsError() {
  return this.state.isError ? 'box-color' : '';
}

render(){
  return <p>hello world</p>
}

Hinweis: Die folgende Art des Schreibens von Objektvariablen wird nicht unterstützt und es wird kein Fehler gemeldet. Der Konsolenklassenname wird als [Objektobjekt] angezeigt, was ungültig ist .

const classObj = {
  'box-show': this.state.isShow,
  'box-color': this.state.isError
}

render(){
  return <p>hello world</p>
}

Im Allgemeinen wird die Funktionsbindungsmethode in Szenarien verwendet, in denen die Projektlogik relativ komplex ist. Bei übermäßiger Verwendung werden die Ansichtsebene und die Logikebene vermischt und verwechselt, was das Lesen und Warten erschwert. Es wird empfohlen, logische Operatoren und ternäre Operationen zu verwenden, um die Klasse dynamisch zu binden.

Array-Syntax

Die React-JSX-Syntax unterstützt keine ClassName-Array-Syntax, versuchen Sie es mit dem Beispiel:

CSS-Datei

.box-hide {
  display: none;
}

.box-color {
  color:red;
}

JS-Datei

this.state = {isShow: false}

render(){
  return <p>hello world</p>
}

Ergebnis der Konsolenanzeige (ungültig, in der Mitte steht ein zusätzliches Komma):

<p>hello world</p>

Hinweis: Da die Array-Syntax nicht unterstützt wird, können Sie die Stile nur in „box-color“ bis „box -hide" ", verwenden Sie den ternären Operator, um es darzustellen, was die Menge an CSS-Code praktisch erhöht.

Bind-Inline-Stil

Objektsyntax

Die Syntax von Stilobjekten ist intuitiver als die von clasName-Objekten und die Verarbeitungsfunktionen sind einfacher. Logische Operatormethoden und Funktionsbindungsmethoden können verwendet werden Bei der Implementierung von className wird im Folgenden nur die Verwendung des ternären Operators vorgestellt:

Ternärer Operator

Ähnlich wie bei Vues vue-if und der wx-if-Anweisung des WeChat-Applets können Sie den Stil einer dynamischen Implementierung verwenden des ternären Operators

js-Datei

render(){
  return <p>hello world</p>
}

Array-Syntax

Die React-JSX-Syntax unterstützt auch keine Style-Array-Syntax, versuchen Sie es mit dem Beispiel:

js-Datei

render(){
  return <p></p>
}

Die Konsole zeigt das Ergebnis (ungültig) an:

<p></p>

Kurz gesagt, um Projektanforderungen mit hoher Qualität abzuschließen und immer komplexere Geschäftsszenarien zu bewältigen, die eine große Anzahl von Doms umfassen Elemente, Es wird nicht empfohlen, eine Stilvariable willkürlich zu benennen und sie dann an Klasse und Stil zu binden.

Empfohlene verwandte Artikel:

HTML-Implementierung einer einfachen Registrierungsseite (mit Code)

Link-Tag-Link-CSS und @import-Laden Was ist der Unterschied?

Das obige ist der detaillierte Inhalt vonSo implementieren Sie die dynamische Bindung von Klasse und Stil in React-JSX (mit Beispielen). 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
HTML: Erstellen der Struktur von WebseitenHTML: Erstellen der Struktur von WebseitenApr 14, 2025 am 12:14 AM

HTML ist der Eckpfeiler der Erstellung von Webseitenstruktur. 1. HTML definiert die Inhaltsstruktur und die Semantik und Verwendung usw. Tags. 2. Stellen Sie semantische Marker wie usw. zur Verfügung, um den SEO -Effekt zu verbessern. 3. Um die Benutzerinteraktion durch Tags zu verwirklichen, achten Sie auf die Verifizierung der Form. 4. Verwenden Sie fortschrittliche Elemente wie in Kombination mit JavaScript, um dynamische Effekte zu erzielen. 5. Zu den häufigen Fehlern gehören nicht abgegebene Bezeichnungen und nicht geeignete Attributwerte, und Überprüfungstools sind erforderlich. 6. Optimierungsstrategien umfassen das Reduzieren von HTTP -Anforderungen, die Komprimierung von HTML, die Verwendung semantischer Tags usw.

Von Text zu Websites: Die Kraft von HTMLVon Text zu Websites: Die Kraft von HTMLApr 13, 2025 am 12:07 AM

HTML ist eine Sprache, mit der Webseiten erstellt, die Webseitenstruktur und -inhalt über Tags und Attribute definiert werden. 1) HTML organisiert die Dokumentstruktur über Tags, wie z. B.. 2) Der Browser analysiert HTML, um das DOM zu erstellen und die Webseite zu rendern. 3) Neue Merkmale von HTML5, wie z. B. Multimedia -Funktionen. 4) Zu den häufigen Fehlern gehören nicht abgestimmte Bezeichnungen und nicht geeignete Attributwerte. 5) Die Optimierungsvorschläge umfassen die Verwendung semantischer Tags und die Reduzierung der Dateigröße.

HTML, CSS und JavaScript verstehen: Ein AnfängerhandbuchHTML, CSS und JavaScript verstehen: Ein AnfängerhandbuchApr 12, 2025 am 12:02 AM

WebdevelopmentRelieSonHtml, CSS und JavaScript: 1) HtmlStructuresContent, 2) CSSstylesit und 3) JavaScriptaddssinteraktivität, Bildung von TheBasisofModerernwebexperiences.

Die Rolle von HTML: Strukturierung von WebinhaltenDie Rolle von HTML: Strukturierung von WebinhaltenApr 11, 2025 am 12:12 AM

Die Rolle von HTML besteht darin, die Struktur und den Inhalt einer Webseite durch Tags und Attribute zu definieren. 1. HTML organisiert Inhalte über Tags wie das Lesen und Verständnis. 2. Verwenden Sie semantische Tags wie usw., um die Zugänglichkeit und SEO zu verbessern. 3. Optimierung des HTML -Codes kann die Ladegeschwindigkeit und die Benutzererfahrung der Webseite verbessern.

HTML und Code: Ein genauerer Blick auf die TerminologieHTML und Code: Ein genauerer Blick auf die TerminologieApr 10, 2025 am 09:28 AM

HtmlisaspecifictypeofcodeFocusedonstructuringuringwebcontent, während "Code" breitincludesluages ​​-ähnlichjavaScriptandpythonforfunctionality.1) htmldefineswebpageStructureStags.2) "Code" cometesaWiNrangeOfLanguagesForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForfirsInsForfunctionNacts

HTML, CSS und JavaScript: Wesentliche Tools für WebentwicklerHTML, CSS und JavaScript: Wesentliche Tools für WebentwicklerApr 09, 2025 am 12:12 AM

HTML, CSS und JavaScript sind die drei Säulen der Webentwicklung. 1. HTML definiert die Webseitenstruktur und verwendet Tags wie z.

Die Rollen von HTML, CSS und JavaScript: KernverantwortungDie Rollen von HTML, CSS und JavaScript: KernverantwortungApr 08, 2025 pm 07:05 PM

HTML definiert die Webstruktur, CSS ist für Stil und Layout verantwortlich, und JavaScript ergibt eine dynamische Interaktion. Die drei erfüllen ihre Aufgaben in der Webentwicklung und erstellen gemeinsam eine farbenfrohe Website.

Ist HTML für Anfänger leicht zu lernen?Ist HTML für Anfänger leicht zu lernen?Apr 07, 2025 am 12:11 AM

HTML ist für Anfänger geeignet, da es einfach und leicht zu lernen ist und schnell Ergebnisse sehen kann. 1) Die Lernkurve von HTML ist glatt und leicht zu beginnen. 2) Beherrschen Sie einfach die grundlegenden Tags, um Webseiten zu erstellen. 3) hohe Flexibilität und kann in Kombination mit CSS und JavaScript verwendet werden. 4) Reiche Lernressourcen und moderne Tools unterstützen den Lernprozess.

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

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),

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft