react
라우팅
campanula
2023. 8. 10. 16:48
장점
1. 보기 쉽고 익숙하다.
2. 더욱 높은 활용도
컴포넌트
프로젝트 생성
npm init react-app book-react
라우팅: 경로를 의미하는 Route와 진행을 뜻하는 ing가 합쳐진 단어로, '경로를 지정하는 과정' 의미, 페이지 라우팅은 요청에 따라 적절한 페이지를 반환하는 일련의 과정
리액트 라우터 설치(프로젝트 설정 후0
npm i react-router-dom
실행 방법
npm start
프로젝트에 라우터 적용하기
리액트 라우터가 제공하는 BrowserRouter컴포넌트로 App을 감싼다.
import { BrowserRouter } from 'react-router-dom';
root.render(
/*<React.StrictMode>
<App />
</React.StrictMode>*/
<BrowserRouter>
<App/>
</BrowserRouter>
);
book-react1
경로 설정, route, link to
이벤트를 사용할 때 주의 사항
이벤트 이름은 카멜 표기법으로 작성
이벤트에 실행할 자바스크립트 코드를 전달하는 것이 아니라, 함수 형태의 값을 전달
DOM요소에만 이벤트를 설정
keycode===13은 엔터
const App =() => {
const [book, setBook] = useState(books);
const onDelete=(targetId)=>{
setBook(book.filter((it)=>it.id !== targetId))
}
return (
<div className="App">
{/**리액트 라우터로 페이지 라우팅을 구현하는 앱에서는 Link라는 컴포넌트를 이용한다.
* <Link to='이동할 경로'>링크 이름</Link>
*/}
<div className='Nav'>
<Link to={"/"}>Home</Link>
<Link to={"/add"}>Add</Link>
<Link to={"/list"}>List</Link>
</div>
<Routes>
{/*현재 URL 경로에 맞게 적절할 Route 컴포넌트를 페이지에 랜더링한다. */}
<Route path="/" element={<Home/>}/>
<Route path="/add" element={<Add />}/>
<Route path ="/list" element={<List book={book} onDelete={onDelete} />}/>
</Routes>
</div>
);
}