Inhaltsverzeichnis
HTML-Klasse binden
Objektsyntax
1. Verwenden Sie logische Operatoren
2. Verwenden Sie den ternären Operator
3. Mit Funktionen
Array-Syntax
Bind-Inline-Stil
Ternärer Operator
Heim Web-Frontend HTML-Tutorial So implementieren Sie die dynamische Bindung von Klasse und Stil in React-JSX (mit Beispielen)

So implementieren Sie die dynamische Bindung von Klasse und Stil in React-JSX (mit Beispielen)

Aug 08, 2018 pm 02:34 PM

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 className={ &#39;box-color&#39;:this.state.isError }>hello world</p>
}
Nach dem Login kopieren

kann erreicht werden. Die Syntax lautet wie folgt:

1. Verwenden Sie logische Operatoren

CSS-Datei

.box-color {
  color:red;
}
Nach dem Login kopieren

js-Datei

render(){
  return <p className={ this.state.isError && &#39;box-color&#39; }>hello world</p>
}
Nach dem Login kopieren
2. Verwenden Sie den ternären Operator

CSS-Datei

.box-show {
  display: block;
}

.box-hide {
  display: none;
}
Nach dem Login kopieren
render(){
  return <p className={ this.state.isShow ? &#39;box-show&#39; : &#39;box-hide&#39; }>hello world</p>
}
Nach dem Login kopieren
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 className={ this.getIsError() }>hello world</p>
}
Nach dem Login kopieren

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 className={ classObj }>hello world</p>
}
Nach dem Login kopieren

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;
}
Nach dem Login kopieren

JS-Datei

this.state = {isShow: false}

render(){
  return <p className={ this.state.isShow ? &#39;box-color&#39; : [ &#39;box-color&#39;, &#39;box-hide&#39;] }>hello world</p>
}
Nach dem Login kopieren

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

<p class="box-color, box-hide">hello world</p>
Nach dem Login kopieren

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 style={ this.state.isShow ? {display: &#39;inline-block&#39;} : { display: &#39;none&#39;} }>hello world</p>
}
Nach dem Login kopieren

Array-Syntax

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

js-Datei

render(){
  return <p style={ this.state.isShow ? {color: &#39;red&#39;} : [{color: &#39;red&#39;}, {display: &#39;inline-block&#39;}] }></p>
}
Nach dem Login kopieren

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

<p></p>
Nach dem Login kopieren

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!

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

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 vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 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)

Was ist der Zweck des & lt; Fortschritts & gt; Element? Was ist der Zweck des & lt; Fortschritts & gt; Element? Mar 21, 2025 pm 12:34 PM

Der Artikel erörtert den HTML & lt; Progress & gt; Element, Absicht, Styling und Unterschiede vom & lt; Meter & gt; Element. Das Hauptaugenmerk liegt auf der Verwendung & lt; Fortschritt & gt; Für Aufgabenabschluss und & lt; Meter & gt; für stati

Was ist der Zweck des & lt; datalist & gt; Element? Was ist der Zweck des & lt; datalist & gt; Element? Mar 21, 2025 pm 12:33 PM

Der Artikel erörtert den HTML & lt; Datalist & gt; Element, das die Formulare verbessert, indem automatische Vorschläge bereitgestellt, die Benutzererfahrung verbessert und Fehler reduziert werden.Character Count: 159

Was ist der Zweck des & lt; Meter & gt; Element? Was ist der Zweck des & lt; Meter & gt; Element? Mar 21, 2025 pm 12:35 PM

Der Artikel erörtert das HTML & lt; Meter & gt; Element, verwendet zur Anzeige von Skalar- oder Bruchwerten innerhalb eines Bereichs und seine gemeinsamen Anwendungen in der Webentwicklung. Es differenziert & lt; Meter & gt; von & lt; Fortschritt & gt; und Ex

Was sind die besten Praktiken für die Kompatibilität des Cross-Browsers in HTML5? Was sind die besten Praktiken für die Kompatibilität des Cross-Browsers in HTML5? Mar 17, 2025 pm 12:20 PM

In Artikel werden Best Practices zur Gewährleistung der HTML5-Cross-Browser-Kompatibilität erörtert und sich auf die Erkennung von Merkmalen, die progressive Verbesserung und die Testmethoden konzentriert.

Wie verwende ich HTML5 -Formularvalidierungsattribute, um die Benutzereingabe zu validieren? Wie verwende ich HTML5 -Formularvalidierungsattribute, um die Benutzereingabe zu validieren? Mar 17, 2025 pm 12:27 PM

In dem Artikel werden unter Verwendung von HTML5 -Formularvalidierungsattributen wie Erforderlich, Muster, Min, MAX und Längengrenzen erörtert, um die Benutzereingabe direkt im Browser zu validieren.

Was ist das Ansichtsfenster -Meta -Tag? Warum ist es wichtig für reaktionsschnelles Design? Was ist das Ansichtsfenster -Meta -Tag? Warum ist es wichtig für reaktionsschnelles Design? Mar 20, 2025 pm 05:56 PM

In dem Artikel wird das Ansichtsfenster -Meta -Tag erörtert, das für das reaktionsschnelle Webdesign auf mobilen Geräten unerlässlich ist. Es wird erläutert, wie die ordnungsgemäße Verwendung eine optimale Skalierung von Inhalten und Benutzerinteraktion gewährleistet, während Missbrauch zu Design- und Zugänglichkeitsproblemen führen kann.

Was ist der Zweck des & lt; iframe & gt; Etikett? Was sind die Sicherheitsüberlegungen bei der Verwendung? Was ist der Zweck des & lt; iframe & gt; Etikett? Was sind die Sicherheitsüberlegungen bei der Verwendung? Mar 20, 2025 pm 06:05 PM

Der Artikel erörtert das & lt; iframe & gt; Der Zweck von Tag, externe Inhalte in Webseiten, seine gemeinsamen Verwendungen, Sicherheitsrisiken und Alternativen wie Objekt -Tags und APIs einzubetten.

Gitee Pages statische Website -Bereitstellung fehlgeschlagen: Wie können Sie einzelne Dateien 404 Fehler beheben und beheben? Gitee Pages statische Website -Bereitstellung fehlgeschlagen: Wie können Sie einzelne Dateien 404 Fehler beheben und beheben? Apr 04, 2025 pm 11:54 PM

GitePages statische Website -Bereitstellung fehlgeschlagen: 404 Fehlerbehebung und Auflösung bei der Verwendung von Gitee ...

See all articles