我正在使用React-router,当我点击链接按钮时,它工作得很好,但当我刷新我的网页时,它没有加载我想要的东西。
例如,我在localhost/joblist和一切都很好,因为我到达这里按下一个链接。但如果我刷新网页,我会得到:
Cannot GET /joblist
默认情况下,它不是这样工作的。最初我有我的URL localhost/#/和localhost/#/joblist,他们工作得很好。但我不喜欢这种类型的URL,所以试图删除#,我写道:
Router.run(routes, Router.HistoryLocation, function (Handler) {
React.render(<Handler/>, document.body);
});
这个问题不会发生在localhost/,这个总是返回我想要的。
这个应用程序是单页的,所以/joblist不需要向任何服务器询问任何事情。
我的整个路由器。
var routes = (
<Route name="app" path="/" handler={App}>
<Route name="joblist" path="/joblist" handler={JobList}/>
<DefaultRoute handler={Dashboard}/>
<NotFoundRoute handler={NotFound}/>
</Route>
);
Router.run(routes, Router.HistoryLocation, function (Handler) {
React.render(<Handler/>, document.body);
});
用Laravel在React中实现JavaScript SPA的解决方案
公认的答案是对为什么会发生这样的问题的最好解释。如前所述,您必须同时配置客户端和服务器端。
在你的blade模板中,包括JavaScript绑定文件,确保像这样使用URL外观:
<script src="{{ URL::to('js/user/spa.js') }}"></script>
在路由中,确保将此添加到刀片模板所在的主端点。例如,
Route::get('/setting-alerts', function () {
return view('user.set-alerts');
});
以上是刀片模板的主要端点。现在再添加一条可选路线,
Route::get('/setting-alerts/{spa?}', function () {
return view('user.set-alerts');
});
发生的问题是,首先加载刀片模板,然后加载React路由器。当你加载'/setting-alerts'时,它会加载HTML内容和JavaScript代码。
但是当你加载'/setting-alerts/about'时,它首先在服务器端加载。因为它在服务器端,所以这个位置上没有任何东西,并且它返回not found。当你有可选的路由器时,它加载同一个页面,React路由器也被加载,然后React加载器决定显示哪个组件。
假设你有以下Home route定义:
<Route exact path="/" render={routeProps => (
<Home routeProps={routeProps}/>
)}/>
{/* Optional catch-all router */}
<Route render={routeProps => (
<div><h4>404 not found</h4></div>
)}/>
在你的Home组件中,你可以在ComponentWillMount事件中拦截请求,
const searchPath = this.props.routeProps.location.search;
if (searchPath){
this.props.routeProps.history.push("/" + searchPath.replace("?",""));
}
else{
/*.... originally Home event */
}
现在,不是在URL处调用/joblist,而是请求/?<Home>组件将自动将请求重定向到/joblist(注意路径中有额外的问号)。