Reputation: 323
import "./App.scss";
import Header from "./containers/Header/Header";
import Home from "./containers/Home/Home";
import { BrowserRouter as Router, Route, Switch } from "react-router-dom";
import SingleMoviePage from "./containers/SingleMoviePage/SingleMoviePage";
const App = () => {
return (
<Router>
<Switch>
<div className="app">
<Route exact path={"/" | "/page"}>
<Header />
<Home />
</Route>
<Route path="/movie/:page/:genre/:id" component={SingleMoviePage} />
</div>
</Switch>
</Router>
);
};
export default App;
Hi.When i click to card component i want to go SinglePageComponent but issue is when i go to SinglePageComponent all components render
and my DOM looks like:
<div class="app">
<div class="header">...</div>
<div class="home">...</div>
<div class="single-movie">...</div>
</div>
I want it look like this.
<div class="app">
<div class="single-movie">...</div>
</div>
Upvotes: 0
Views: 59
Reputation: 329
This is because you are rendering your header and home components unconditionally. Try doing this:
<Router>
<div className="app">
<Switch>
<Route exact path={["/","/page"]} render= {()=>{
return(
<Header/>
<Home/>
)}
}/>
<Route path="/movie/:page/:genre/:id" component={SingleMoviePage} />
</Switch>
</div>
</Router>
Upvotes: 1