In your example code, there is no <Link>
, I think you’re putting the <Link>
outside the <BrowserRouter>
and this is not allowed, as it is in the documentation and the documentation code already shows this however, ie the <Link>
has to be inside <BrowserRouter>
, example:
import React from "react";
import {
BrowserRouter as Router,
Switch,
Route,
Link
} from "react-router-dom";
export default function App() {
return (
<Router>
<div>
<nav>
<ul>
<li>
<Link to="/">Home</Link>
</li>
<li>
<Link to="/about">About</Link>
</li>
<li>
<Link to="/users">Users</Link>
</li>
</ul>
</nav>
{/* A <Switch> looks through its children <Route>s and
renders the first one that matches the current URL. */}
<Switch>
<Route path="/about">
<About />
</Route>
<Route path="/users">
<Users />
</Route>
<Route path="/">
<Home />
</Route>
</Switch>
</div>
</Router>
);
}
function Home() {
return <h2>Home</h2>;
}
function About() {
return <h2>About</h2>;
}
function Users() {
return <h2>Users</h2>;
}
Rights link site code: https://reactrouter.com/web/guides/quick-start
and that’s how it should be done.
You can only use the Link inside the Router, put your router code here that will be easier to help.
– Lucas Brogni
@Lucasbrogni Prontin
– Anderson Leite