理解react-router路由跳转路径上的“#”

本文深入探讨React Router中browserHistory与hashHistory的区别,解释为何URL中会出现#号,及如何配置服务端路径以支持React应用。同时,详述history对象的属性与方法,以及提供了React路由配置的实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

碎碎念:之前用react-router的时候直接用的旧项目默认配置,没有仔细去了解为什么url上面会自带#,趁着周末查阅了一下资料,自己总结一下。

一、理解什么是react-router history

直接拿开发文档里的原话:

React Router 是建立在 history 之上的。 简而言之,一个 history 知道如何去监听浏览器地址栏的变化, 并解析这个 URL 转化为 location 对象, 然后 router 使用它匹配到路由,最后正确地渲染对应的组件。

 history分为三种: browserHistory / hashHistory / createMemoryHistory

其中browserHistory / hashHistory 两种常用于前端路由。那么两者最显著的区别就是:

使用hashHistory作为路由,url上会自带参数 # ,形如 192.168.0.1:3000/#/main

而 browserHistory 则是:192.168.0.1:3000/main

原因:

1. 两者对路由路径处理的方式不一样,hashHistory是对#后面的路径进行处理,由前端通过html history(使用这种路由,可以在控制台打印出当前路由history的情况(console.log(this.props.history)))进行管理。而browserHistory则需要通过服务端的配置 前端才可以正确拿到返回。

2.那么为什么browserHistory需要服务端配置才可以呢?

 Browser history 是使用 React Router 的应用推荐的 history。它使用浏览器中的 History API 用于处理 URL,创建一个像example.com/some/path这样真实的 URL

browserHistory访问后台接口的时候后台收到的是形如 “/mian/index” 的形式,如果后台没有做映射,那么后台的所有资源都是存放在 “/” 下的,这个时候就拿不到数据。但如果是第一次进入主页面,发送的请求是 “/” 形式的话,就拿得到数据,如果是进入其他页面,或者来回跳转,url产生了变化,发送的请求变成了“/main/index” 之类的话,就是我上面说的情况了。所以服务端必须要做相应的资源路径映射。

再看hashHistory,真实URL其实是指向服务器资源,比如我们经常使用的API接口,也是一个真实URL的资源路径,当通过真实URL访问网站的时候,通过hashHistory来生成的URL就不会出现这样的问题,因为他不是指向真实的路由。hashHistory的路径是从#开始的,它的所有处理是在前端完成,可以打开控制台看一下请求列表里,发送出去的请求api是不带#的,就是说前端已经处理过url发送给后台。(我是这么理解的,不知道是否准确,如果有误大神可以帮忙纠正一下哈~)

二、配置服务端路径

看了很多文章都是直接copy开发文档的代码,这里直接指路文档地址:

http://react-guide.github.io/react-router-cn/docs/guides/basics/Histories.html#creatememoryhistory

三、history属性详解

常见字段:

length: number 浏览历史堆栈中的条目数
action: string 路由跳转到当前页面执行的动作,分为 PUSH, REPLACE, POP
location: object 当前访问地址信息组成的对象,具有如下属性:
pathname: string URL路径
search: string URL中的查询字符串
hash: string URL的 hash 片段
state: string 例如执行 push(path, state) 操作时,location 的 state 将被提供到堆栈信息里,state 只有在 browser 和 memory history 有效。
push(path, [state]) 在历史堆栈信息里加入一个新条目。
replace(path, [state]) 在历史堆栈信息里替换掉当前的条目
go(n) 将 history 堆栈中的指针向前移动 n。
goBack() 等同于 go(-1)  eg. this.props.history.goBack() 等于浏览器左上角的回退
goForward 等同于 go(1)
block(prompt) 阻止跳转
history 对象是可变的,因为建议从 <Route> 的 prop 里来获取 location,而不是从 history.location 直接获取

四、react路由配置示例

import React from 'react'
import {HashRouter as Router, Redirect, Route, Switch} from 'react-router-dom';

import App from '../components/App'
import Home from '../components/Home'
import About from '../components/About'
import Features from '../components/Features'

render(
  <Router>
      <Switch>
         <Route path={'/app'} component={App}/>
         <Route path={'/home'} component={Home} />
         <Route path={'/About'} component={About} />
         <Route path={'/features/:id'} component={Features}/>
         <Route path="*" component={Home}/>
      </Switch>
  </Router>,
  document.getElementById('app')
)

参考文档:

http://react-guide.github.io/react-router-cn/docs/guides/basics/Histories.html

https://blog.youkuaiyun.com/qq_29854831/article/details/79636095

https://blog.youkuaiyun.com/oqqmihu123/article/details/59529481

    
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值