react-router-dom中的BrowserRouter和HashRouter


 

HashRouter包裹下訪問根服務:假設為 localhost:3000/

 1 import { HashRouter as Router, Route, Redirect } from 'react-router-dom';  
 2 // as的作用為將HashRouter重命名為Router,這樣的好處是在反復測試HashRouter和BrowserRouter時,可以免去組件修改
 3 
 4 import Home from './pages/Home/index';
 5 import Hooks from './pages/Hooks/index';
 6 
 7 export default function App() {
 8   return (
 9     <Router>
10       <Route path="/">
11         <Redirect to="/home" />
12       </Route>
13       <Route path="/home" component={Home} />
14       <Route path="/hooks" component={Hooks} />
15     </Router>
16   )
17 }

操作一: 瀏覽器直接輸入localhost:3000/
結果: 路由自動變為localhost:3000/#/home,可正常訪問.

操作二: 瀏覽器直接輸入localhost:3000/#/hooks
結果: 可正常訪問

將HashRouter更改為BrowserRouter

1 import { BrowserRouter as Router, Route, Redirect } from 'react-router-dom';  // 使用BrowserRouter

操作一: 瀏覽器直接輸入localhost:3000/
結果: 路由自動變為localhost:3000/home,可正常訪問

操作二: 瀏覽器直接輸入localhost:3000/hooks
結果: 瀏覽器無法獲得正確的結果,Cannot GET /hooks

操作二: 瀏覽器直接輸入localhost:3000/home
結果: 瀏覽器無法獲得正確的結果,Cannot GET /home

操作三: 瀏覽器直接輸入localhost:3000/成功后,點擊內容<Link to="home">Home</Link>
結果: 可成功跳轉

那么問題來了:為什么HashRouter可以直接訪問路徑,而BrowserRouter會出現找不到路由的情況?為什么HashRouter在前端跳轉就能成功?

服務器路由: browserRouter, 前端路由: hashRouter

browserRouter

如果前端使用了browserRouter,每次改變路由時,會向服務器發送請求,因為服務器未配置對應的路徑指向對應的文件,自然導致出現404的情況.(對於初始化頁面,即路由為/時,不會發送請求)

因此在使用browserHistory需要再加一層服務器配置(node/nginx),讓前端發送的請求映射到對應的html文件上.

hashRouter

由於hashRouter會在路徑上添加/#/,而/#/后面的所有都不會發送到服務器端,即對於服務器而言,路徑依舊是localhost:3000,路由切換在前端完成。

但是官方會更推薦使用browserRouter,貌似是因為其構建於H5的History API,比起hashRouter,它多出了更多的方法操控url

 

 

轉載自:https://www.cnblogs.com/soyxiaobi/p/11096940.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM