React Router v6 の「[PrivateRoute] はコンポーネントではありません」エラーを修正する方法?

DDD
リリース: 2024-11-01 03:16:27
オリジナル
635 人が閲覧しました

How to Fix

エラー: [PrivateRoute] は ではありません。コンポーネント

このエラーは、React Router v6 を使用し、プライベート ルートを作成しようとすると発生します。 PrivateRoute.js 内の指定されたコードは Route コンポーネントを返そうとしますが、そのままではエクスポートされません。

解決策:

この問題を解決するには、PrivateRoute を変更します。 .js ファイルは次のようになります。

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;
ログイン後にコピー

App.js ファイルで、プライベート ルートが次のように定義されていることを確認します。

<Route exact path='/' element={<PrivateRoute />}>
  <Route exact path='/' element={<Home />} />
</Route>
ログイン後にコピー

この改訂されたコードにより、PrivateRoute コンポーネントがは Route コンポーネントとして認識され、プライベート ルーティングに対して適切に機能します。

以上がReact Router v6 の「[PrivateRoute] はコンポーネントではありません」エラーを修正する方法?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート