我可以为两条路线使用相同的路由处理程序

时间:2014-10-14 09:28:43

标签: reactjs react-router

我定义了这两条路线:

<Route name='register' handler={Register} >
    <Route name='registerpromotion' path='/registerpromotion/:promotionCode' handler={Register}/>
</Route>

因此两个路由都使用名为Register的相同处理程序。

registerpromotion 路由的情况下,我传入一个属性,在寄存器路由的情况下,我没有。

我无法使其工作 - promotionCode属性始终未定义。

有谁知道你是否可以为两条路线使用相同的处理程序?

非常感谢!

1 个答案:

答案 0 :(得分:0)

此代码来自react-router issue #410 rpflorence:

/** @jsx React.DOM */
var React = require('react');
var Router = require('react-router');
var Route = Router.Route;
var Routes = Router.Routes;
var Link = Router.Link;

var Foo = React.createClass({  
  render: function() { 
    return (
      <div>
        <p>hello</p>
        <p>stuffId: {this.props.params.stuffId}</p>
        <ul>
          <li><Link to="root">top</Link></li>
          <li><Link to="stuff" params={{stuffId: 'one'}}>one</Link></li>
          <li><Link to="stuff" params={{stuffId: 'two'}}>two</Link></li>
        </ul>
        <this.props.activeRouteHandler />
      </div>
    );
  }
});

var routes = (
  <Routes>
    <Route name="root" path="/" handler={Foo}>
      <Route name="stuff" path=":stuffId" handler={Foo}/>
    </Route>
  </Routes>
);

React.renderComponent(routes, document.body);