react-router里的两种路由方式有什么不同
在React Router中,createBrowserRouter
和createHashRouter
的主要区别在于路由模式的选择:
兼容性差异
- **
createBrowserRouter
**(基于HTML5 History API)不兼容IE9及以下版本,但支持现代主流浏览器。 - **
createHashRouter
**(基于URL哈希值)兼容性更好,可适配更多浏览器,包括低版本IE。
地址栏表现形式
- **
createBrowserRouter
**的URL路径中不含#
(如localhost:3000/demo/test
)。 - **
createHashRouter
**的URL路径包含#
(如localhost:3000/#/demo/test
)。
刷新页面影响
- **
createBrowserRouter
**刷新页面后,路由状态(如参数)不受影响,因状态保存在浏览器历史记录中。 - **
createHashRouter
**刷新页面会导致路由状态丢失,需重新加载数据。
使用场景建议
- **
createBrowserRouter
**适用于需要优雅URL且兼容性要求不高的场景(如公网项目)。 - **
createHashRouter
**适用于兼容性优先的场景(如内网项目或老旧浏览器环境)。