Hello fellow friends I am trying to create my own app but facing issues after updating the react-router-dom to 6.02 I am getting this error
Error: [Home] is not a Route component. All component children of Routes must be a Route or <React.Fragment>
the code is the following
import { BrowserRouter, Route, Routes } from "react-router-dom";
import Navbar from "./components/Navbar/Navbar";
import Home from "./pages/home/Home";
import Login from "./pages/login/Login";
import Signup from "./pages/signup/Signup";
function App() {
return (
<div className="App">
<BrowserRouter>
<Navbar />
<Routes>
<Route exact path="/">
<Home />
</Route>
<Route path="/login">
<Login />
</Route>
<Route path="/signup">
<Signup />
</Route>
</Routes>
</BrowserRouter>
</div>
);
}
export default App;
We can verify the React version by directly visiting the package. json file and see the React app version at dependencies: {} section as given below. { ... ... ... "name": "react-app", "version": "0.1. 0", "private": true, "dependencies": { "@testing-library/jest-dom": "^4.2.
The useLocation hook returns the location object that represents the current URL.
Only Route components can be a child of Routes. If we follow the v6 docs then we'll see the authentication pattern is to use a wrapper component to handle the authentication check and redirect.
All component children of <Routes> must be a <Route> or <React.Fragment> #24 No description provided. Sorry, something went wrong. same issue for me any fix ?
Error: [Home] is not a Route component. All component children of Routes must be a Route or <React.Fragment>
Error: [PrivateRoute] is not a <Route> component. All component children of <Routes> must be a <Route> or <React.Fragment> If authorization is successful, the element will show. Otherwise, it will navigate to the login page. Only Route components can be a child of Routes.
<Route path="/" element={<Home />} />
This change is necessary because react-router 6 reserves the child prop of <Route>
for nesting routes.
Migrating to v6
React router package has some sort of code changes with respect to the versions.
// React router v4 or v5
<Route path="/" component={Home} />
// React router v5.1
<Route exact path="/">
<Home />
</Route>
// React router v6
<Route path="/" element={<Home />} />
For more: React Router - Upgrading to V6
So, you can use V6 syntax to resolve this issue.
This error happens because of the new Upgrade of the react-router-dom library.
This is the solution to your problem.
import { BrowserRouter as Router, Route, Routes } from 'react-router-dom';
function App() {
return (
<div className="App">
<Router>
<Navbar />
<Routes>
<Route exact path='/' element={<Home />} />
<Route path='/register' element={<Signup />} />
<Route path='/Login' element={<Login />} />
</Routes>
</Router>
</div>
);
}
export default App;
This is the solution for this version "react-router-dom": "^6.0.2",
Note:- There are some more features than this in the new version of react-router-dom
.
https://reactrouter.com/docs/en/v6
Uncaught Error: [Home] is not a component. All component children of must be a or <React.Fragment>
Solution
function App() {
return (
<>
<Router>
<Routes>
<Route exact path="/" element={<Home />} />
</Routes>
</Router>
</>
);
}
i have the same problem too,if you use v6 try not to use close tag for route and use element property to define your component,for examole for the Home rout you should do this
<Route exact path="/" element={<Home />} />
Fixed for multiple components under same Route
. Wrap multiple components inside <>
and </>
tags.
<Route exact path="/" element={<><AddTodo addTodo={addTodo} /><Todos todos={todos} onDelete={onDelete} /></>} />
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With