Maison >interface Web >js tutoriel >Comment corriger l'erreur « [PrivateRoute] n'est pas un composant » dans React Router v6 ?

Comment corriger l'erreur « [PrivateRoute] n'est pas un composant » dans React Router v6 ?

DDD
DDDoriginal
2024-11-01 03:16:27722parcourir

How to Fix

Erreur : [PrivateRoute] n'est pas un composant

Cette erreur se produit lors de l'utilisation de React Router v6 et de la tentative de création de routes privées. Le code donné dans PrivateRoute.js tente de renvoyer un composant Route, mais il n'est pas exporté en tant que tel.

Solution :

Pour résoudre ce problème, modifiez le PrivateRoute .js comme suit :

import React from 'react';
import { Navigate, Outlet } from 'react-router-dom';

const PrivateRoute = () => {
    const auth = null; // determine if authorized, from context or however you're doing it

    // If authorized, return an outlet that will render child elements
    // If not, return element that will navigate to login page
    return auth ? <Outlet /> : <Navigate to="/login" />;
}

export default PrivateRoute;

Dans le fichier App.js, assurez-vous que la route privée est définie comme suit :

<Route exact path='/' element={<PrivateRoute />}>
  <Route exact path='/' element={<Home />} />
</Route>

Ce code révisé garantira que le composant PrivateRoute est reconnu comme un composant de route et fonctionnera correctement pour le routage privé.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn