Heim > Web-Frontend > js-Tutorial > Wie übergebe ich Requisiten in der „Link'-Komponente von React-Router?

Wie übergebe ich Requisiten in der „Link'-Komponente von React-Router?

Patricia Arquette
Freigeben: 2024-11-01 04:44:02
Original
764 Leute haben es durchsucht

How to Pass Props in React-Router's

Props im „Link“ von React-Router übergeben

Wenn Sie React mit React-Router verwenden, können Sie Eigenschaften mithilfe von an eine neue Ansicht übergeben eine geänderte Syntax im Komponente.

Aktualisierte Syntax in React-Router v4 und v5

Um Requisiten in React-Router v4 und v5 zu übergeben, verwenden Sie die folgende Syntax:

<Link to={{ pathname: path, query: queryObject, search: searchString }}>
  ...
</Link>
Nach dem Login kopieren

wobei:

  • Pfadname ist der Pfad zur neuen Ansicht.
  • Abfrage ist ein Objekt, das Abfrageparameter enthält.
  • Suche ist eine Zeichenfolge, die das darstellt Abfragezeichenfolge, z. B. ?foo=bar.

Zugriff auf Requisiten in der Zielkomponente

In der Zielkomponente können Sie auf die über übergebenen Requisiten zugreifen Verknüpfen Sie mithilfe der folgenden Techniken:

Veraltete Verwendung der Komponente „withRouter“ höherer Ordnung:

  • Umschließen Sie die Zielkomponente mit withRouter, die den Zugriff auf die Komponente ermöglicht Match- und Location-Requisiten:
const NewView = withRouter(OriginalView);
Nach dem Login kopieren

Aktuelle Implementierung mit Hooks:

  • Verwenden Sie die useParams- und useLocation-Hooks innerhalb der Funktionskomponente, um auf die zuzugreifen Übereinstimmungs- und Standort-Requisiten:
const NewView = () => {
  const { testvalue } = useParams();
  const { query, search } = useLocation();

  return (
    <div>
      {testvalue} {query.backUrl}
    </div>
  );
};
Nach dem Login kopieren

Beispiel

Betrachten Sie das folgende Beispiel:

App.js:

<Link to={{ pathname: '/ideas/:testvalue', query: { testvalue: 'hello' } }}>Create Idea</Link>
Nach dem Login kopieren

CreateIdeaView.js:

const CreateIdeaView = () => {
  const { testvalue } = useParams();
  console.log(testvalue); // prints 'hello'

  return (
    <div>{testvalue}</div>
  );
};
Nach dem Login kopieren

In diesem Beispiel wird durch Klicken auf den Link „Idee erstellen“ die Eigenschaft testvalue mit dem Wert hello an die CreateIdeaView-Komponente übergeben.

Hinweis:

  • Der Pfad in der Link-Komponente sollte den Parameterplatzhalter enthalten, z. B. Pfad: '/ideas/:testvalue'.
  • Der useParams-Hook gibt ein Objekt mit allen im Pfad definierten Parametern zurück.
  • Der useLocation-Hook gibt ein Objekt mit Informationen über den aktuellen Standort zurück, einschließlich Abfrage und Suche.
  • Die Abfrage ist ein Objekt, das Schlüssel-Wert-Paare enthält, während die Suchzeichenfolge die gesamte Abfragezeichenfolge enthält.

Das obige ist der detaillierte Inhalt vonWie übergebe ich Requisiten in der „Link'-Komponente von React-Router?. 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