最近,自己在摸索react的时候,遇到一个很奇葩的问题,大概是这样的:

我从列表页使用Link跳转到详情页面,列表页面的路由是'/list',详情页面的路由是'/list/detail',由于详情页面的路由里边也包含了'/list',所以在点击列表页面要去详情页时,地址栏里的地址变了,可详情页面却在列表页面里边直接加载出来了,导致俩页面成为一个页面了,这在我写vue的时候从来就不会出现的问题,怎么到了react就出现这个问题了呢?

于是,我就上网搜索解决的办法,搜了一大通,各种解决办法都有,看来不止我一个人遇到了这样的问题,大部分同行给出的解决办法是使用withRouter,那么withRouter到底是干嘛的?

有解释说:

withRouter可以包装任何自定义组件,将react-router 的 history,location,match 三个对象传入

无需一级级传递 react-router 的属性,当需要用的router

属性的时候,将组件包一层withRouter,就可以拿到需要的路由信息

还有解释说:

如果使用了react-router-redux,则可以直接从state中的router属性中获取location。不需要再使用withRouter获取路由信息了

云山雾罩...

既然有人说使用withRouter可以解决我这样的问题,那我就试了试,压根不管用啊。

继续搜索解决办法,于是又看到了有人说可能是因为路由'/list/detail'放在了路由'/list'的后边,即:

<Route path="/list" exact component={List} />
<Route path="/list/detail" exact component={Detail} />

我心想还有这说法?抱着试试看的心态,就赶紧换成了:

<Route path="/list/detail" exact component={Detail} />
<Route path="/list" exact component={List} />

结果可想而知,这种方法只不过是将显示详情内容的地方给挪到了列表的上边,这算什么?这算什么?这算什么?

其实在这里,如下图:

还是继续找寻解决办法吧,于是又看到了有人说可能是路由表的外边又多套了一个Router,于是我就赶紧去检查了我的路由代码,没有啊,没有多嵌套啊。丧啊!!!

抱着不解决问题誓不罢休的精神,继续搜索解决办法。这次,皇天不负有心人啊,终于找到了解决办法:

<Route path="/list" exact component={List} />

喏,只是在路由‘/list’配置的时候加了一个exact,那么这玩意儿到底又是什么鬼呢?

exact属性用来指明这个路由是不是排他的匹配

这是因为v4中的路由默认都是非排他的,这一点和v3的实现思路截然不同。V3中的路由是排他性的,这意味着只有一个路由可以匹配,V4中的路由则是包含性的,这意味着一个地址可以匹配多个并同时渲染。说白了,如果没有exact属性,List组件( 地址为'/list' )和其子组件( 地址为'/list/detail' )就会同时绘制在一个页面上。大概其呢就是精确匹配吧,我是这么理解的。

问题终于解决,看来办法总是会比问题多,其实也说明了一个问题,还是对react-router的API不熟悉,也算是长个教训吧!

最后,或许由于大家的写法不太一样,所以本文中出现的其他的解决办法可能也是正确的解决办法,大家可以自行试一试。

参考:

https://blog.csdn.net/weixin_30363263/article/details/80992288

https://www.jianshu.com/p/548674270455

https://www.jianshu.com/p/bf6b45ce5bcc

react-router路由地址变了页面却没有跳转的解决办法的更多相关文章

  1. react ---- Router路由的使用和页面跳转

    React-Router的中文文档可以参照如下链接: http://react-guide.github.io/react-router-cn/docs/Introduction.html 首先,我们 ...

  2. React初识整理(四)--React Router(路由)

    官网:https://reacttraining.com/react-router 后端路由:主要做路径和方法的匹配,从而从后台获取相应的数据 前端路由:用于路径和组件的匹配,从而实现组件的切换. 如 ...

  3. < react router>: (路由)

    < react router> (路由): 思维导图: Atrial   文件夹下的index.js 文件内容: import React, { Component } from 'rea ...

  4. HTTP 错误 500.19 请求的页面的相关配置数据无效 解决办法

    "HTTP 错误 500.19 请求的页面的相关配置数据无效" 解决办法   HTTP 错误 500.19 - Internal Server Error无法访问请求的页面,因为该 ...

  5. pycharm自动调整html页面代码缩进不正确的解决办法

    pycharm自动调整html页面代码缩进不正确的解决办法

  6. Juniper SRX550防火墙web页面CPU达到100%的故障解决办法

    Juniper SRX550防火墙web页面CPU达到100%的故障解决办法 利用telnet远程连接主机,对web页面注销重新登录即可,在配置中输入命令:run restart web-manage ...

  7. jquery 的ajax无刷新上传文件之后,页面还是会莫名的刷新-----解决办法

    文件上传用到全局数组: $_FILES 只需要把下面的 <button onclick="post()">提交</button> 改为 <input ...

  8. 【react router路由】<Router> <Siwtch> <Route>标签

    博客 https://www.jianshu.com/p/ed5e56994f13?from=timeline 文档 http://react-guide.github.io/react-router ...

  9. react router路由传参

    今天,我们要讨论的是react router中Link传值的三种表现形式.分别为通过通配符传参.query传参和state传参. ps:进入正题前,先说明一下,以下的所有内容都是在react-rout ...

随机推荐

  1. arguments.callee.caller

    1.Arguments Arguments是一个类似数组但不是数组的对象,说它类似数组是因为其具有数组一样的访问性质及方式,可以由arguments[n]来访问对应的单个参数的值,并拥有数组长度属性l ...

  2. 2018-2019-2 20165237《网络对抗技术》Exp2 后门原理与实践

    2018-2019-2 20165237<网络对抗技术>Exp2 后门原理与实践 一.实践目标 使用netcat获取主机操作Shell,cron启动 使用socat获取主机操作Shell, ...

  3. 中国交建 WAF 基础平台 http://waf.ccccltd.cn/

    中国交建  WAF 基础平台  http://waf.ccccltd.cn/

  4. java学习笔记04-基本数据类型

    编写一款可用的软件,离不开对数据的操作(经常有人说:程序=数据+算法).数据可能有很多类型,比如对于年龄来说,数据就是整数. 对于金额来,数据是带小数的.在java中,可以分为内置数据类型和引用数据类 ...

  5. LightOJ 1348 (树链剖分 + 线段树(树状数组))

    题目 Link 分析 典型的树链剖分题, 树链剖分学习资料 Code #include <bits/stdc++.h> using namespace std; const int max ...

  6. Mysql的子查询相关知识,少但是精

    Mysql子查询 概念分析: 根据相关性分: (1)不相关子查询:一条Sql语句中含有多条SELECT语句,先执行子查询,再执行外查询,子查询可对立运行 关键字:(1)先子查询,再外查询 (2)可以对 ...

  7. MySQL ERROR 1054(42S22)

    修改用户的密码,网上搜到的命令为如下 执行后报错 ERROR 1054(42S22) Unknown column 'password' in ‘field list’ 错误的原因是 5.7版本下的m ...

  8. python 对Excel表格的读取

    import xlrd flbrd = "D:\\考勤系统.xlsx" ws = xlrd.open_workbook(flbrd) # 获取所有sheet名字:ws.sheet_ ...

  9. 马拉车算法——求回文子串个数zoj4110

    zoj的测评姬好能卡时间.. 求回文子串的个数:只要把p[i]/2就行了: 如果s_new[i]是‘#’,算的是没有中心的偶回文串 反之是奇回文串 /* 给定两个字符串s,t 结论:s,t不相同的第一 ...

  10. Django提交表单时遇到403错误:CSRF verification failed

    这个问题是由跨站点伪造请求(CRSF)造成的,要彻底的弄懂这个问题就要理解什么是CRSF,以及Django提供的CSRF防护机制是怎么工作的. 什么是CSRF CSRF, Cross Site Req ...