首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >React-Router -未捕获TypeError:无法读取未定义的属性“”getCurrentLocation“”

React-Router -未捕获TypeError:无法读取未定义的属性“”getCurrentLocation“”
EN

Stack Overflow用户
提问于 2016-11-30 01:50:55
回答 2查看 39.9K关注 0票数 51

我使用的是最新版本的react-router (版本^3.0.0)。

我使用ES5编写了以下路由:

routes.js

代码语言:javascript
复制
var React = require("react");
var Router = require("react-router");
var AuthorPage = require('./components/authors/authorPage')
var App = require('./components/app')
var Route = Router.Route;

var routes = (
    <Route path="/" component={App}>
        <Route path="authors" component={AuthorPage}/>
     </Route>
);

module.exports = routes;

在另一个名为main.js的JS文件中,我执行以下调用:

main.js

代码语言:javascript
复制
var React= require("react");
var ReactDom = require("react-dom");
var Router = require('react-router').Router;
var routes = require('./routes');
ReactDom.render(<Router routes={routes}></Router>, document.getElementById('app'));

当我运行代码时,在Google Chrome开发人员工具中得到以下异常:

未捕获TypeError:无法读取未定义的属性“”getCurrentLocation“”

为什么会这样呢?我遗漏了什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-11-30 02:06:08

您没有将历史记录传递给<Router>

有关更多信息,请查看histories documentation

票数 58
EN

Stack Overflow用户

发布于 2017-03-21 17:08:56

有相同的错误,用下面的方法解决:

添加

代码语言:javascript
复制
var hashHistory = ReactRouter.hashHistory;

在路由器设置中,历史记录等于hashHistory

代码语言:javascript
复制
<Router history={hashHistory}>

所以在你的例子中:

代码语言:javascript
复制
var routes = (
<Router history={hashHistory}>
    <Route path="/" component={App}>
        <Route path="authors" component={AuthorPage}/>
     </Route>
</Router>
);
票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40872481

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档