Inhaltsverzeichnis
Welche verschiedenen Möglichkeiten gibt es, React-Click-Ereignisse zu schreiben? Kommen wir gleich zur Sache. Lassen Sie uns zunächst die richtige Methode zum Hinzufügen eines Ereignisses zu einer Schaltfläche erläutern:
handleClick () { // do something here }
Nach dem Login kopieren
Klicken Sie auf die Schaltfläche und drucken Sie den Zeiger auf examplePage this:" >Der unten angegebene Code lautet: Fügen Sie ein Onclick-Ereignis hinzu (ein vollständiges jsx) für eine Schaltfläche
handleClick () { // do something here }
Nach dem Login kopieren
Klicken Sie auf die Schaltfläche und drucken Sie den Zeiger auf examplePage this:
handleClick ist in der Klasse examplePage definiert. " >Da handleClick eine Pfeilfunktion ist, ist dies also der Definitionskontext. handleClick ist in der Klasse examplePage definiert.
handleClick wird ausgeführt, wenn auf der Seite auf eine Schaltfläche geklickt wird. Der Kontext ist also die HTML-Seite Dies ist undefiniert und verweist nicht auf die Beispielseite. " >Da handleClick eine gewöhnliche Funktion ist, ist dies also der Ausführungskontext. handleClick wird ausgeführt, wenn auf der Seite auf eine Schaltfläche geklickt wird. Der Kontext ist also die HTML-Seite Dies ist undefiniert und verweist nicht auf die Beispielseite.
Heim Web-Frontend Front-End-Fragen und Antworten Welche verschiedenen Möglichkeiten gibt es, React-Click-Ereignisse zu schreiben?

Welche verschiedenen Möglichkeiten gibt es, React-Click-Ereignisse zu schreiben?

Apr 22, 2022 am 10:28 AM
react

Schreibmethode: 1. Verwenden Sie „onClick={this.handleClick}“ 2. Verwenden Sie „onClick={this.handleClick.bind(this)}“ 3. Verwenden Sie „{(params)=>this.handleClick (params)}".

Welche verschiedenen Möglichkeiten gibt es, React-Click-Ereignisse zu schreiben?

Die Betriebsumgebung dieses Tutorials: Windows 10-System, Reaktionsversion 17.0.1, Dell G3-Computer.

Welche verschiedenen Möglichkeiten gibt es, React-Click-Ereignisse zu schreiben? Kommen wir gleich zur Sache. Lassen Sie uns zunächst die richtige Methode zum Hinzufügen eines Ereignisses zu einer Schaltfläche erläutern:


Die richtige Methode zum Hinzufügen eines Onclick-Ereignisses zu einer Schaltfläche

Es werden keine Parameter übergeben verwendet (gewöhnliche Funktion) zum Definieren von

onClick = { this .handleClick.bind(this) }

    // handleClick用箭头函数定义时,为onClick添加事件应该这么写:<Button onClick = { this.handleClick }></Button>
    Nach dem Login kopieren
  • handleClick ist wie folgt definiert:
  • handleClick = () => { // do something here};
    Nach dem Login kopieren
    Pass-Parameter


    // handleClick kann mit onClick = { (params ) => this.handleClick(params) }

    // handleClick用普通函数定义时,为onClick添加事件应该这么写:<Button onClick = { this.handleClick.bind(this) }></Button>
    Nach dem Login kopieren
    Als nächstes analysieren wir, warum es richtig ist, so zu schreiben:


    Diese Zeigeranalyse

    Verstehen Dieses Problem mit den folgenden Sätzen:

    • Die Pfeilfunktion hat kein eigenes Dies, also ist ihr Dies: Dies des Kontexts, wenn sie definiert ist.
    • Eine gewöhnliche Funktion hat ihr eigenes Dies, also ist sie Dies: Dies des Kontexts wenn es ausgeführt wird

    Schauen wir uns zuerst das erste an. Eine Möglichkeit zum Schreiben:

    1. onClick = { this.handleClick } + Pfeilfunktion

    Der unten angegebene Code lautet: Fügen Sie ein Onclick-Ereignis hinzu (ein vollständiges jsx) für eine Schaltfläche
    handleClick () { // do something here }
    Nach dem Login kopieren
    Klicken Sie auf die Schaltfläche und drucken Sie den Zeiger auf examplePage this:

    this: examplePage {props: Object, context: {}, refs: {}, updater: Object, state: {}, …}


    Analyse:

    Wenn auf die Schaltfläche geklickt wird, wird das handleClick-Ereignis als Handling-Funktion bezeichnet.

    Da handleClick eine Pfeilfunktion ist, ist dies also der Definitionskontext. handleClick ist in der Klasse examplePage definiert.

    Das zeigt also auf examplePage

    Mal sehen, ob die Pfeilfunktion in eine normale Funktion geändert wird. Situation:

    2. onClick = { this.handleClick.bind(this) } + gewöhnliche Funktion

    Schauen wir uns zuerst an Was wird von console.log(this) ausgegeben, wenn bind(this) nicht verwendet wird:
       // handleClick可以是箭头函数,也可以是普通函数<Button onClick = { (params) => this.handleClick(params) }></Button>
      Nach dem Login kopieren
    • Klicken Sie auf die Schaltfläche und drucken Sie Folgendes aus:
    • this: undefiniert
    • Analyse:
    • Wenn auf die Schaltfläche geklickt wird, Die Ereignisverarbeitungsfunktion handleClick wird aufgerufen.

      Da handleClick eine gewöhnliche Funktion ist, ist dies also der Ausführungskontext. handleClick wird ausgeführt, wenn auf der Seite auf eine Schaltfläche geklickt wird. Der Kontext ist also die HTML-Seite Dies ist undefiniert und verweist nicht auf die Beispielseite.

      Hinweis: In der strikten Version ist dies standardmäßig nicht mehr Fenster, sondern undefiniert. Der Modulcode ist immer strikter Moduscode.

      Alle Teile einer ClassDeclaration oder ClassExpression sind strikt Moduscode.

      Sie müssen also bind verwenden, um diesen Zeiger zu ändern, d der Renderfunktion (die auf die Klasse examplePage zeigt) als Variable in handleClick ist ursprünglich eine gewöhnliche Funktion, und dies ist die Funktion this des Ausführungskontexts (d. h. undefiniert), aber weil bind(this) übergeben wurde, zeigte dies darauf examplePage

      Zu diesem Zeitpunkt verweist dies also auf examplePage, was das Problem löst, dass dies undefiniert ist

      • Nachdem man die beiden oben genannten verstanden hat, ist die letzte Seite leicht zu verstehen
      • 3. onClick = { (params) => ; this.handleClick(params) } + Gewöhnliche Funktionen/Pfeilfunktionen können verwendet werden Pfeilfunktion (params) => this.handleClick(params) wird aufgerufen, also ist dies das This des Kontexts, wenn er definiert ist,
      • handleClick ist in der Klasse examplePage definiert,
      • Das zeigt also auf examplePage
      Gemäß Diese Idee: Solange das onClick-Antwortereignis mit einer Pfeilfunktion geschrieben wird, zeigt diese beim Aufruf auf die Komponentenklasse und es wird kein Problem geben



      Dann, wenn keine Parameter übergeben werden, schreiben Sie einfach:

      // examplePage.jsximport React from 'react';import { Button } from 'antd';class examplePage extends React.Component {
          // 2. 定义handleClick事件
          handleClick = () => {
              console.log(this); //3. this指向examplePage
          }
      
          render() {
              return (
                  <p>
                  // 1. 为onClick绑定 handleClick事件处理函数
                      <Button onClick = { this.handleClick }>click me</Button>
                  </p>
              )
          }}export default examplePage;
      Nach dem Login kopieren
      Dies ist jedoch nicht möglich, da React () => this.handleClick() direkt analysiert und handleClick aufgerufen wird, was onClick = „Das Ergebnis des Aufrufs von handleClick“ entspricht.

      Also, wenn keine Parameter übergeben werden, Sie kann nur so schreiben:

      // examplePage.jsximport React from 'react';import { Button } from 'antd';class examplePage extends React.Component {
          // 2. !将箭头函数改为普通函数
          handleClick () {
              console.log(this); // 3. this 为 undefined
          }
      
          render() {
              return (
                  <p>
                  // 1. 为onClick绑定 handleClick事件处理函数
                      <Button onClick = { this.handleClick }>click me</Button>
                  </p>
              )
          }}export default examplePage;
      Nach dem Login kopieren
      Zusammenfassung
        Die ersten drei Fragen können beantwortet werden
        • 什么情况下需要bind(this)?
          答: onClick传入的事件处理函数是普通函数的时候,需要bind(this)来改变指向
        • 为什么要用bind(this)?
          答:如果不用bind(this), this会指向undefined
        • 可以不用bind(this)吗?
          答:用箭头函数 (用箭头函数定义事件处理函数)
        //定义handleClick事件
        handleClick = () => {
              // do something here
        };
        
        //为onClick绑定handleClick事件处理函数
        <Button onClick = {this.handleClick}></Button> // 不传参
        <Button onClick = {(param) => this.handleClick(param) }></Button> // 传参
        Nach dem Login kopieren

        推荐学习:《react视频教程

      Das obige ist der detaillierte Inhalt vonWelche verschiedenen Möglichkeiten gibt es, React-Click-Ereignisse zu schreiben?. 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

      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

      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)

      So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket Sep 26, 2023 pm 07:46 PM

      So erstellen Sie eine Echtzeit-Chat-Anwendung mit React und WebSocket Einführung: Mit der rasanten Entwicklung des Internets hat die Echtzeitkommunikation immer mehr Aufmerksamkeit auf sich gezogen. Live-Chat-Apps sind aus dem modernen Sozial- und Arbeitsleben nicht mehr wegzudenken. In diesem Artikel wird erläutert, wie Sie mit React und WebSocket eine einfache Echtzeit-Chat-Anwendung erstellen, und es werden spezifische Codebeispiele bereitgestellt. 1. Technische Vorbereitung Bevor wir mit der Erstellung einer Echtzeit-Chat-Anwendung beginnen, müssen wir die folgenden Technologien und Tools vorbereiten: React: eine zum Erstellen

      Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Sep 28, 2023 am 10:48 AM

      React-Leitfaden zur Front-End- und Back-End-Trennung: So erreichen Sie die Front-End- und Back-End-Entkopplung und die unabhängige Bereitstellung. Es sind spezifische Codebeispiele erforderlich. In der heutigen Webentwicklungsumgebung ist die Front-End- und Back-End-Trennung zu einem Trend geworden. Durch die Trennung von Front-End- und Back-End-Code kann die Entwicklungsarbeit flexibler und effizienter gestaltet und die Zusammenarbeit im Team erleichtert werden. In diesem Artikel wird erläutert, wie Sie mithilfe von React eine Front-End- und Back-End-Trennung erreichen und so die Ziele der Entkopplung und unabhängigen Bereitstellung erreichen. Zuerst müssen wir verstehen, was Front-End- und Back-End-Trennung ist. Im traditionellen Webentwicklungsmodell sind Front-End und Back-End gekoppelt

      So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask Sep 27, 2023 am 11:09 AM

      So erstellen Sie mit React und Flask einfache und benutzerfreundliche Webanwendungen. Einführung: Mit der Entwicklung des Internets werden die Anforderungen an Webanwendungen immer vielfältiger und komplexer. Um den Anforderungen der Benutzer an Benutzerfreundlichkeit und Leistung gerecht zu werden, wird es immer wichtiger, moderne Technologie-Stacks zum Aufbau von Netzwerkanwendungen zu verwenden. React und Flask sind zwei sehr beliebte Frameworks für die Front-End- und Back-End-Entwicklung, und sie arbeiten gut zusammen, um einfache und benutzerfreundliche Webanwendungen zu erstellen. In diesem Artikel erfahren Sie, wie Sie React und Flask nutzen

      So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ Sep 28, 2023 pm 08:24 PM

      So erstellen Sie eine zuverlässige Messaging-Anwendung mit React und RabbitMQ Einführung: Moderne Anwendungen müssen zuverlässiges Messaging unterstützen, um Funktionen wie Echtzeitaktualisierungen und Datensynchronisierung zu erreichen. React ist eine beliebte JavaScript-Bibliothek zum Erstellen von Benutzeroberflächen, während RabbitMQ eine zuverlässige Messaging-Middleware ist. In diesem Artikel wird erläutert, wie Sie React und RabbitMQ kombinieren, um eine zuverlässige Messaging-Anwendung zu erstellen, und es werden spezifische Codebeispiele bereitgestellt. RabbitMQ-Übersicht:

      Anleitung zum Debuggen von React-Code: So finden und beheben Sie Front-End-Fehler schnell Anleitung zum Debuggen von React-Code: So finden und beheben Sie Front-End-Fehler schnell Sep 26, 2023 pm 02:25 PM

      React-Code-Debugging-Leitfaden: So finden und beheben Sie Front-End-Fehler schnell. Einführung: Bei der Entwicklung von React-Anwendungen stoßen Sie häufig auf eine Vielzahl von Fehlern, die zum Absturz der Anwendung oder zu fehlerhaftem Verhalten führen können. Daher ist die Beherrschung von Debugging-Fähigkeiten eine wesentliche Fähigkeit für jeden React-Entwickler. In diesem Artikel werden einige praktische Techniken zum Auffinden und Beheben von Front-End-Fehlern vorgestellt und spezifische Codebeispiele bereitgestellt, um Lesern dabei zu helfen, Fehler in React-Anwendungen schnell zu finden und zu beheben. 1. Auswahl der Debugging-Tools: In Re

      React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Sep 29, 2023 pm 05:45 PM

      ReactRouter-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Mit der Popularität von Single-Page-Anwendungen ist das Front-End-Routing zu einem wichtigen Bestandteil geworden, der nicht ignoriert werden kann. Als beliebteste Routing-Bibliothek im React-Ökosystem bietet ReactRouter umfangreiche Funktionen und benutzerfreundliche APIs, wodurch die Implementierung des Front-End-Routings sehr einfach und flexibel ist. In diesem Artikel wird die Verwendung von ReactRouter vorgestellt und einige spezifische Codebeispiele bereitgestellt. Um ReactRouter zuerst zu installieren, benötigen wir

      So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery Sep 26, 2023 pm 06:12 PM

      So verwenden Sie React und Google BigQuery zum Erstellen schneller Datenanalyseanwendungen. Einführung: Im heutigen Zeitalter der Informationsexplosion ist die Datenanalyse zu einem unverzichtbaren Bindeglied in verschiedenen Branchen geworden. Unter anderem ist die Entwicklung schneller und effizienter Datenanalyseanwendungen für viele Unternehmen und Einzelpersonen zum Ziel geworden. In diesem Artikel wird erläutert, wie Sie mit React und Google BigQuery eine schnelle Datenanalyseanwendung erstellen, und es werden detaillierte Codebeispiele bereitgestellt. 1. Übersicht React ist ein Werkzeug zum Erstellen

      So erstellen Sie Echtzeit-Datenverarbeitungsanwendungen mit React und Apache Kafka So erstellen Sie Echtzeit-Datenverarbeitungsanwendungen mit React und Apache Kafka Sep 27, 2023 pm 02:25 PM

      So verwenden Sie React und Apache Kafka zum Erstellen von Echtzeit-Datenverarbeitungsanwendungen. Einführung: Mit dem Aufkommen von Big Data und Echtzeit-Datenverarbeitung ist die Erstellung von Echtzeit-Datenverarbeitungsanwendungen für viele Entwickler zum Ziel geworden. Die Kombination von React, einem beliebten Front-End-Framework, und Apache Kafka, einem leistungsstarken verteilten Messaging-System, kann uns beim Aufbau von Echtzeit-Datenverarbeitungsanwendungen helfen. In diesem Artikel wird erläutert, wie Sie mit React und Apache Kafka Echtzeit-Datenverarbeitungsanwendungen erstellen

      See all articles