Heim >Web-Frontend >js-Tutorial >Beherrschen der Navigation in React mit dem useNavigate Hook
Der useNavigate-Hook ist Teil von React Router (v6 und höher) und wird verwendet, um programmgesteuert zwischen verschiedenen Routen in Ihrer Anwendung zu navigieren. Im Gegensatz zur herkömmlichen Navigation (z. B. Klicken auf Links) können Sie mit dem useNavigate-Hook dynamisch auf der Grundlage von Benutzeraktionen wie Formularübermittlungen, Schaltflächenklicks oder Statusänderungen navigieren.
Dieser Hook ersetzt den älteren useHistory-Hook von React Router v5 und erleichtert die Handhabung der Navigation innerhalb funktionaler Komponenten.
Der useNavigate-Hook gibt eine Funktion zurück, mit der programmgesteuert zu einer bestimmten Route navigiert werden kann. Sie können dieser Funktion einen Pfad oder ein Standortobjekt übergeben und sie führt die Navigation entsprechend aus.
const navigate = useNavigate();
Hier ist ein einfaches Beispiel dafür, wie Sie den useNavigate-Hook verwenden können, um programmgesteuert zu navigieren, wenn ein Benutzer auf eine Schaltfläche klickt.
import React from 'react'; import { useNavigate } from 'react-router-dom'; const Home = () => { const navigate = useNavigate(); const goToProfile = () => { // Navigate to the profile page navigate('/profile'); }; return ( <div> <h2>Home Page</h2> <button onClick={goToProfile}>Go to Profile</button> </div> ); }; export default Home;
Sie können useNavigate auch verwenden, um zu dynamischen Routen zu navigieren, bei denen Sie Parameter übergeben.
const navigate = useNavigate();
Beim Navigieren können Sie die Option „Ersetzen“ verwenden, um den aktuellen Eintrag im Verlaufsstapel zu ersetzen, anstatt einen neuen zu verschieben. Das bedeutet, dass der Benutzer nicht zur vorherigen Route zurückkehrt, wenn er auf die Schaltfläche „Zurück“ des Browsers klickt.
import React from 'react'; import { useNavigate } from 'react-router-dom'; const Home = () => { const navigate = useNavigate(); const goToProfile = () => { // Navigate to the profile page navigate('/profile'); }; return ( <div> <h2>Home Page</h2> <button onClick={goToProfile}>Go to Profile</button> </div> ); }; export default Home;
Mit der Navigation können Sie zusätzliche Status übergeben, die dann über useLocation.
an der Zielroute abgerufen werden können
import React from 'react'; import { useNavigate } from 'react-router-dom'; const UserList = () => { const navigate = useNavigate(); const goToUserProfile = (userId) => { // Navigate to the profile of a specific user by ID navigate(`/user/${userId}`); }; return ( <div> <h2>User List</h2> <button onClick={() => goToUserProfile(1)}>Go to User 1's Profile</button> <button onClick={() => goToUserProfile(2)}>Go to User 2's Profile</button> </div> ); }; export default UserList;
Auf der Route /settings können Sie wie folgt auf den bestandenen Status zugreifen:
import React from 'react'; import { useNavigate } from 'react-router-dom'; const SubmitForm = () => { const navigate = useNavigate(); const handleSubmit = () => { // Perform form submission logic // Then navigate to a "Thank You" page, replacing the current entry in history navigate('/thank-you', { replace: true }); }; return ( <div> <h2>Submit Form</h2> <button onClick={handleSubmit}>Submit</button> </div> ); }; export default SubmitForm;
Weiterleitung nach dem Absenden des Formulars:
Nach dem Absenden eines Formulars (z. B. Benutzerregistrierung) können Sie den Benutzer zu einer Erfolgs- oder Anmeldeseite weiterleiten.
Bedingte Navigation:
Basierend auf Benutzeraktionen oder -bedingungen (wie Authentifizierung) können Sie dynamisch zu verschiedenen Routen navigieren.
Programmatisches Routing:
Sie können programmgesteuert auf der Grundlage benutzerdefinierter Logik navigieren, z. B. wenn eine Aktion abgeschlossen oder ein Ereignis ausgelöst wird.
Navigation nach erfolgreichem API-Aufruf:
Nach einem erfolgreichen API-Aufruf (z. B. Anmelden) können Sie Benutzer zu ihrer Profilseite oder ihrem Dashboard weiterleiten.
Der useNavigate-Hook in React Router ist ein leistungsstarkes Tool zur Handhabung der programmgesteuerten Navigation in Funktionskomponenten. Es ermöglicht Ihnen, basierend auf Benutzeraktionen oder Anwendungsstatus dynamisch zu verschiedenen Routen zu navigieren. Mit Optionen wie Ersetzen und der Möglichkeit, den Status zu übergeben, bietet useNavigate Flexibilität für die Steuerung des Navigationsverhaltens in React-Anwendungen.
Das obige ist der detaillierte Inhalt vonBeherrschen der Navigation in React mit dem useNavigate Hook. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!