react-router-dom中的BrowserRouter和HashRouter

Posted Ly_cat

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react-router-dom中的BrowserRouter和HashRouter相关的知识,希望对你有一定的参考价值。

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

1、browserRouter

如果前端使用了browserRouter,每次改变路由时,会向服务器发送请求,因为服务器未配置对应的路径指向对应的文件,自然导致出现404的情况.(对于初始化页面,即路由为/时,不会发送请求)

因此在使用browserHistory需要再加一层服务器配置(node/nginx),让前端发送的请求映射到对应的html文件上.

2、hashRouter

由于hashRouter会在路径上添加/#/,而/#/后面的所有都不会发送到服务器端,即对于服务器而言,路径依旧是localhost:3000,路由切换在前端完成。

但是官方会更推荐使用browserRouter,貌似是因为其构建于H5的History API,比起hashRouter,它多出了更多的方法操控url。

以上是关于react-router-dom中的BrowserRouter和HashRouter的主要内容,如果未能解决你的问题,请参考以下文章

使用 react-router-dom 中的 Route 时 ReactDOM 渲染出错

React-router-dom + Suspense:gh-pages 部署中的问题

react-router-dom中的BrowserRouter和HashRouter

如何正确使用 react-router-dom 中的 useHistory()?

react-router-dom 中的多页路由问题

react-router-dom 中的 Switch 语句始终加载 Home 路由,没有其他路由