考虑以下几点:React-Router:没有找不到路由?
var AppRoutes = [
<Route handler={App} someProp="defaultProp">
<Route path="/" handler={Page} />
</Route>,
<Route handler={App} someProp="defaultProp">
<Route path="/" handler={Header} >
<Route path="/withheader" handler={Page} />
</Route>
</Route>,
<Route handler={App} someProp="defaultProp">
<Route path=":area" handler={Area} />
<Route path=":area/:city" handler={Area} />
<Route path=":area/:city/:locale" handler={Area} />
<Route path=":area/:city/:locale/:type" handler={Area} />
</Route>
];
我有一个应用程序模板,一个HeaderTemplate中,并且参数组具有相同的处理路线(应用程序模板内)。我希望能够在找不到东西时提供404条路线。例如,/ CA/SanFrancisco应该被Area找到和处理,而/ SanFranciscoz应该是404。
下面是我如何快速测试路线。
['', '/', '/withheader', '/SanFranciscoz', '/ca', '/CA', '/CA/SanFrancisco', '/CA/SanFrancisco/LowerHaight', '/CA/SanFrancisco/LowerHaight/condo'].forEach(function(path){
Router.run(AppRoutes, path, function(Handler, state){
var output = React.renderToString(<Handler/>);
console.log(output, '\n');
});
});
的问题/ SanFranciscoz总是由区页面处理,但我希望它404。另外,如果我加入NotFoundRoute到第一路由配置,所有的区域页面404
<Route handler={App} someProp="defaultProp">
<Route path="/" handler={Page} />
<NotFoundRoute handler={NotFound} />
</Route>,
我在做什么错?
这里有一个可以下载和试验的要点。
https://gist.github.com/adjavaherian/aa48e78279acddc25315
如果你有一个REDX应用程序,你会怎么做:' '在这个句法中:'const routes = { component:Main, childRoutes:[ {路径: '/',组件:首页}, ], indexRoute:{ 成分:主, }, };' –
tatsu
如果你想设置的道具为404 Compontent使用代码: ' } />' –