Heim > Web-Frontend > js-Tutorial > Warum wird meine React onClick-Funktion beim Rendern ausgelöst?

Warum wird meine React onClick-Funktion beim Rendern ausgelöst?

Mary-Kate Olsen
Freigeben: 2024-11-08 05:45:01
Original
675 Leute haben es durchsucht

Why Does My React onClick Function Fire on Render?

React onClick-Funktion beim Rendern auslösen

Beim Erstellen von React-Komponenten, die Listen von Objekten rendern, ist es üblich, sowohl die Objekte als auch eine Funktion zu übergeben für das Löschen als Requisiten. Während die Verwendung von .map() zum Durchlaufen der Objekte Standard ist, kann dies dazu führen, dass die onClick-Funktion beim Rendern vorzeitig ausgelöst wird.

Im bereitgestellten Code rührt das Problem von der Tatsache her, dass die „removeTaskFunction“ direkt aufgerufen wird im onClick-Ereignishandler. Dies bedeutet, dass die Funktion ausgeführt wird, sobald die Komponente gerendert wird, und nicht, wenn auf die Schaltfläche geklickt wird.

Lösung

Um dieses Problem zu beheben, sollte die Funktion übergeben werden als Pfeilfunktion für onClick, um sicherzustellen, dass sie nicht vorzeitig aufgerufen wird. Die korrigierte Zeile sollte wie folgt aussehen:

<button type="submit" onClick={() => this.props.removeTaskFunction(todo)}>Submit</button>
Nach dem Login kopieren

Pfeilfunktionen, die in ES6 eingeführt wurden, verzögern die Ausführung, bis die Funktion aufgerufen wird. In React 0.13.3 oder höher werden Pfeilfunktionen vollständig unterstützt. Durch die Verwendung einer Pfeilfunktion wird der onClick-Handler nur dann ausgelöst, wenn tatsächlich wie beabsichtigt auf die Schaltfläche geklickt wird.

Das obige ist der detaillierte Inhalt vonWarum wird meine React onClick-Funktion beim Rendern ausgelöst?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage