Heim >Web-Frontend >js-Tutorial >Wie kann ich Werte effizient an onClick-Ereignishandler in React JS übergeben?

Wie kann ich Werte effizient an onClick-Ereignishandler in React JS übergeben?

Linda Hamilton
Linda HamiltonOriginal
2024-11-28 03:25:11909Durchsuche

How Can I Efficiently Pass Values to onClick Event Handlers in React JS?

React js onClick-Ereigniswertübergabe

Bei der Arbeit mit React js-Ereignissen kann es schwierig sein, Werte an Methoden zu übergeben. Wir werden dieses Problem angehen, indem wir mehrere Lösungen untersuchen.

1. Pfeilfunktionen verwenden

Die einfachste Methode ist die Verwendung einer Pfeilfunktion:

return (
  <th value={column} onClick={() => this.handleSort(column)}>{column}</th>
);

Pfeilfunktionen erstellen neue Funktionen, die handleSort mit den entsprechenden Parametern aufrufen. Dieser Ansatz generiert jedoch jedes Mal eine neue Funktion, was zu unnötigen erneuten Renderings führt.

2. Extrahieren in Unterkomponenten (empfohlen)

Ein besserer Ansatz besteht darin, die onClick-Ereignisbehandlung in eine Unterkomponente zu extrahieren. Erstellen Sie eine Unterkomponente, die den Handler und den Wert als Requisiten übernimmt:

class TableHeader extends Component {
  handleClick = () => {
    this.props.onHeaderClick(this.props.value);
  };

  render() {
    return (
      <th>
        <th onClick={this.handleClick}>{this.props.column}</th>
      </th>
    );
  }
}

Übergeben Sie in der Hauptkomponente die Handler- und Wert-Requisiten an die Unterkomponente:

{this.props.defaultColumns.map((column) => (
  <TableHeader
    value={column}
    onHeaderClick={this.handleSort}
  />
))}

This stellt sicher, dass sich die Handler-Referenz nie ändert, wodurch unnötige erneute Renderings minimiert werden.

3. ES5-Methode (alt)

Wenn Sie ES5 verwenden, können Sie die Funktion wie folgt an den Komponentenkontext binden:

return (
  <th value={column} onClick={this.handleSort.bind(this, column)}>{column}</th>
);

Das obige ist der detaillierte Inhalt vonWie kann ich Werte effizient an onClick-Ereignishandler in React JS übergeben?. 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