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

Syn*_*BBB 51 browserify reactjs react-router

我正在使用最新版本react-router(版本^ 3.0.0).

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

routes.js:

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;
Run Code Online (Sandbox Code Playgroud)

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

main.js:

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'));
Run Code Online (Sandbox Code Playgroud)

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

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

这是为什么?我错过了什么?

Pau*_*l S 59

你没有将历史传递给你<Router>.

查看历史记录文档以获取更多信息.


小智 10

有同样的错误,这样解决了:

var hashHistory = ReactRouter.hashHistory;
Run Code Online (Sandbox Code Playgroud)

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

<Router history={hashHistory}>
Run Code Online (Sandbox Code Playgroud)

所以在你的情况下:

var routes = (
<Router history={hashHistory}>
    <Route path="/" component={App}>
        <Route path="authors" component={AuthorPage}/>
     </Route>
</Router>
);
Run Code Online (Sandbox Code Playgroud)