Web/JavaScript & JQuery
[React] url에 붙은 # 제거하기
쩨리쩨리
2024. 2. 14. 16:19
반응형
리액트 템플릿을 이용하여 페이지 이동 중 url에 #(해시)가 붙어 있는 것을 발견했다.
리액트에서 url 에 #(해시)가 붙는 경우는 단일 페이지 애플리케이션(SPA, Single Page Application)을 이용할 경우 발견할 수 있다.
하나의 HTML 페이지 안에서 모든 기능이 동작하는 것을 SPA라고 한다. 모든 기능이 하나의 HTML 페이지 안에서 동작하기 때문에, 페이지 로딩 속도가 빠른것이 장점이라고 할 수 있다.
SPA 화면에서 #(해시)가 붙는 이유는 주로 웹 브라우저의 페이지 이동을 감지하고 해당 url을 분석해서 해당 페이지의 컴포넌트를 빠르게 렌더링하기 위해서이다. #(해시)가 없으면 웹 브라우저는 실제로 서버에 새로운 페이지를 요청할 수 있다.
본인은 템플릿 페이지를 커스텀하여 서버에 데이터를 요청한 뒤 렌더링 할 것이기 때문에 해시를 제거해야 한다.
1. 현재 소스
React Router에서 라우팅을 관리하게 되는데, 여기 부분을 수정하면 된다.
아래는 App.js의 코드 예시이다.
import { HashRouter, Routes, Route } from 'react-router-dom';
import DefaultLayout from './DefaultLayout';
import {Login, Register, Page404, Page500} from './OtherPage';
function App() {
return (
<HashRouter>
<Routes>
<Route path="/login" name="Login Page" element={<Login />} />
<Route path="/register" name="Register Page" element={<Register />} />
<Route path="/404" name="Page 404" element={<Page404 />} />
<Route path="/500" name="Page 500" element={<Page500 />} />
<Route path="/" name="Home" element={<DefaultLayout />} />
</Routes>
</HashRouter>
);
}
2. BrowserRouter 사용하기
<HashRouter> 태그 대신 <BrowserRouter>로 바꿔주자. 그러면 #(해시)가 사라진다.
만약, 다시 #(해시)가 필요하다면 <HashRouter>로 바꿔주면 url에 #(해시)가 붙는다.
import { BrowserRouter, Routes, Route } from 'react-router-dom';
import DefaultLayout from './DefaultLayout';
import {Login, Register, Page404, Page500} from './OtherPage';
function App() {
return (
<BrowserRouter>
<Routes>
<Route path="/login" name="Login Page" element={<Login />} />
<Route path="/register" name="Register Page" element={<Register />} />
<Route path="/404" name="Page 404" element={<Page404 />} />
<Route path="/500" name="Page 500" element={<Page500 />} />
<Route path="/" name="Home" element={<DefaultLayout />} />
</Routes>
</BrowserRouter>
);
}
반응형