Inhaltsverzeichnis
In Klassenkomponenten
1, verwendenImperativeHandle
Heim Web-Frontend Front-End-Fragen und Antworten So rufen Sie die Methode der untergeordneten Komponente in der übergeordneten React-Komponente auf

So rufen Sie die Methode der untergeordneten Komponente in der übergeordneten React-Komponente auf

Dec 27, 2022 pm 07:01 PM
前端 react.js

Aufrufmethode: 1. Aufrufe in Klassenkomponenten können mit React.createRef(), funktionaler Deklaration von ref oder props mit dem benutzerdefinierten onRef-Attribut implementiert werden. 2. Aufrufe in Funktionskomponenten und Hook-Komponenten können mit useImperativeHandle oder forwardRef throw implementiert werden ref, um dies zu erreichen.

So rufen Sie die Methode der untergeordneten Komponente in der übergeordneten React-Komponente auf

Die Betriebsumgebung dieses Tutorials: Windows 7-System, React18-Version, Dell G3-Computer.

In React rufen wir häufig die Methode der übergeordneten Komponente in der untergeordneten Komponente auf, normalerweise mithilfe des Props-Callbacks. Manchmal ist es jedoch auch erforderlich, die Methode der untergeordneten Komponente in der übergeordneten Komponente aufzurufen, um eine hohe Kohäsion zu erreichen. Es gibt viele Methoden, wenden Sie sie nach Bedarf an.

In Klassenkomponenten


1, React.createRef()

  • Vorteile: leicht verständlich, mit Referenz versehen.

  • Nachteile: Unterkomponenten, die HOC verwenden, sind nicht verfügbar und können nicht auf echte Unterkomponenten verweisen

    Einige häufig verwendete Schreibmethoden, z. B. in @observer von mobx eingeschlossene Unterkomponenten, gelten beispielsweise nicht für diese Methode. 2. Funktionale Deklaration von Referenzen Das Gleiche, aber die Art und Weise, ref zu definieren, ist anders.

    import React, { Component } from 'react';
    
    class Sub extends Component {
      callback() {
        console.log('执行回调');
      }
      render() {
        return <div>子组件</div>;
      }
    }
    
    class Super extends Component {
      constructor(props) {
        super(props);
        this.sub = React.createRef();
      }
      handleOnClick() {
        this.sub.callback();
      }
      render() {
        return (
          <div>
            <Sub ref={this.sub}></Sub>
          </div>
        );
      }
    }
    Nach dem Login kopieren
3. Verwenden Sie Requisiten, um das onRef-Attribut anzupassen

Vorteile: Wenn die Unterkomponente mit HOC verschachtelt ist, kann sie auch auf die reale Unterkomponente verweisen.
  • Nachteile: Requisitenattribute müssen angepasst werden
  • ...
    
    <Sub ref={ref => this.sub = ref}></Sub>
    
    ...
    Nach dem Login kopieren
Funktionskomponente, Hook-Komponente

1, verwendenImperativeHandle

  • Vorteile: 1. Die Schreibmethode ist einfach und leicht verständlich. 2. Wenn die Unterkomponente ein verschachteltes HOC hat, kann sie auch auf die echte Unterkomponente verweisen
Nachteile: 1. Requisitenattribute müssen angepasst werden 2. Sie müssen die exponierte Methode anpassen. Das Problem besteht jedoch darin, dass withRouter, connect, Form.create und andere Methoden keine Referenz auslösen können. Wenn Child selbst diese Methoden verschachteln muss, können sie grundsätzlich nicht zusammen verwendet werden. ForwardRef selbst wird auch zum Auslösen von Referenzen für untergeordnete Elemente wie Eingaben und anderen nativen Elementen verwendet. Es ist nicht zum Auslösen von Komponentenreferenzen geeignet, da die Verwendungsszenarien von Komponenten zu komplex sind.

import React, { Component } from &#39;react&#39;;
import { observer } from &#39;mobx-react&#39;

@observer
class Sub extends Component {
	componentDidMount(){
    // 将子组件指向父组件的变量
		this.props.onRef && this.props.onRef(this);
	}
	callback(){
		console.log("执行我")
	}
	render(){
		return (<div>子组件</div>);
	}
}

class Super extends Component {
	handleOnClick(){
       // 可以调用子组件方法
		this.Sub.callback();
	}
	render(){
		return (
          <div>
			<div onClick={this.handleOnClick}>click</div>
			<Sub onRef={ node => this.Sub = node }></Sub>	
	   	  </div>)
	}
}
Nach dem Login kopieren
ZusammenfassungEs gibt zwei Situationen, in denen eine übergeordnete Komponente eine Funktion einer untergeordneten Komponente aufruft.

Keine HOC-Verschachtelung von untergeordneten Komponenten: Es wird empfohlen, ref zum direkten Aufrufen zu verwenden.
Bei HOC-Verschachtelung: Es wird empfohlen, benutzerdefinierte zu verwenden Requisiten

  • 【Verwandte Empfehlungen:
  • Redis-Video-Tutorial
  • ,
  • Programmierunterricht

Das obige ist der detaillierte Inhalt vonSo rufen Sie die Methode der untergeordneten Komponente in der übergeordneten React-Komponente auf. 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ß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)

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Erfahren Sie, wie Sie Unit-Tests in Vue3 schreiben Erfahren Sie, wie Sie Unit-Tests in Vue3 schreiben Apr 25, 2023 pm 07:41 PM

Vue.js ist heute ein sehr beliebtes Framework in der Front-End-Entwicklung. Da sich Vue.js ständig weiterentwickelt, werden Unit-Tests immer wichtiger. Heute untersuchen wir, wie man Unit-Tests in Vue.js 3 schreibt, und stellen einige Best Practices sowie häufige Probleme und Lösungen vor.

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Wie lassen sich domänenübergreifende Probleme lösen? Eine kurze Analyse gängiger Lösungen Wie lassen sich domänenübergreifende Probleme lösen? Eine kurze Analyse gängiger Lösungen Apr 25, 2023 pm 07:57 PM

Domänenübergreifend ist ein Szenario, das in der Entwicklung häufig vorkommt und auch ein häufig in Interviews diskutiertes Thema ist. Die Beherrschung gängiger domänenübergreifender Lösungen und der dahinter stehenden Prinzipien kann nicht nur unsere Entwicklungseffizienz verbessern, sondern auch in Vorstellungsgesprächen bessere Leistungen erbringen.

PHP und Vue: eine perfekte Kombination von Front-End-Entwicklungstools PHP und Vue: eine perfekte Kombination von Front-End-Entwicklungstools Mar 16, 2024 pm 12:09 PM

PHP und Vue: eine perfekte Kombination von Front-End-Entwicklungstools In der heutigen Zeit der rasanten Entwicklung des Internets ist die Front-End-Entwicklung immer wichtiger geworden. Da Benutzer immer höhere Anforderungen an das Erlebnis von Websites und Anwendungen stellen, müssen Frontend-Entwickler effizientere und flexiblere Tools verwenden, um reaktionsfähige und interaktive Schnittstellen zu erstellen. Als zwei wichtige Technologien im Bereich der Front-End-Entwicklung können PHP und Vue.js in Kombination als perfekte Waffe bezeichnet werden. In diesem Artikel geht es um die Kombination von PHP und Vue sowie um detaillierte Codebeispiele, die den Lesern helfen sollen, diese beiden besser zu verstehen und anzuwenden

Erfahren Sie mehr über Puffer in Node Erfahren Sie mehr über Puffer in Node Apr 25, 2023 pm 07:49 PM

Zu Beginn lief JS nur auf der Browserseite. Es war einfach, Unicode-codierte Zeichenfolgen zu verarbeiten, aber es war schwierig, binäre und nicht Unicode-codierte Zeichenfolgen zu verarbeiten. Und Binär ist das Datenformat der niedrigsten Ebene des Computer-, Video-/Audio-/Programm-/Netzwerkpakets

Häufig gestellte Fragen von Front-End-Interviewern Häufig gestellte Fragen von Front-End-Interviewern Mar 19, 2024 pm 02:24 PM

In Front-End-Entwicklungsinterviews decken häufige Fragen ein breites Themenspektrum ab, darunter HTML/CSS-Grundlagen, JavaScript-Grundlagen, Frameworks und Bibliotheken, Projekterfahrung, Algorithmen und Datenstrukturen, Leistungsoptimierung, domänenübergreifende Anfragen, Front-End-Engineering, Designmuster sowie neue Technologien und Trends. Interviewerfragen sollen die technischen Fähigkeiten, die Projekterfahrung und das Verständnis des Kandidaten für Branchentrends beurteilen. Daher sollten Kandidaten in diesen Bereichen umfassend vorbereitet sein, um ihre Fähigkeiten und Fachkenntnisse unter Beweis zu stellen.

Wie verwende ich die Go-Sprache für die Front-End-Entwicklung? Wie verwende ich die Go-Sprache für die Front-End-Entwicklung? Jun 10, 2023 pm 05:00 PM

Mit der Entwicklung der Internet-Technologie hat die Front-End-Entwicklung immer mehr an Bedeutung gewonnen. Insbesondere die Popularität mobiler Geräte erfordert eine Front-End-Entwicklungstechnologie, die effizient, stabil, sicher und einfach zu warten ist. Als sich schnell entwickelnde Programmiersprache wird die Go-Sprache von immer mehr Entwicklern verwendet. Ist es also möglich, die Go-Sprache für die Front-End-Entwicklung zu verwenden? Als Nächstes wird in diesem Artikel ausführlich erläutert, wie die Go-Sprache für die Front-End-Entwicklung verwendet wird. Werfen wir zunächst einen Blick darauf, warum die Go-Sprache für die Front-End-Entwicklung verwendet wird. Viele Leute denken, dass die Go-Sprache eine ist

See all articles