我有这些场景
设置页面 - >结果页面 - >详情页面
用户选择设置,点击下一步,获取结果,然后点击更多详细信息。
详细信息页面 - >结果页面
用户从详细信息页面返回结果页面。这导致完全重新渲染,导致我再次无法点击服务器(我将结果存储在数组中)。
详细信息页面 - >结果页面 - >设置页面 - >结果页面
用户转到详细信息,然后返回结果(想要获取存储的结果),然后返回设置页面,进行更改然后返回到结果页面(现在我想再次从服务器获取完整的数据)。< / p>
我想知道是否存在反应路由器,以确定我是否通过浏览器历史记录来到该页面,或者我是否正在进行前进动作。
答案 0 :(得分:1)
在React Router中,如果路由器调用该组件的子路径,则组件将保持挂载状态。因此,在您的示例中,您可以执行以下操作:
<Route path="items" component={Results}>
<Route path=":id" component={Detail} />
</Route>
这样,Results
组件在安装Detail
组件时无法卸载,因为Detail
是Results
的子组件。但是,如果您不希望在详细信息中看到结果组件被渲染,则只能在它们存在时进行渲染。如下所示:
class Results extends React.Component {
render() {
if (this.props.children) {
// This will enter Detail component
return this.props.children;
}
return (
// Render results component
);
}
}
答案 1 :(得分:1)
我一直在寻找相同的东西,然后终于找到了一个看似简单的解决方案。
快速解答:
我使用history.action
值来确定用户是来自后退按钮还是来自经典导航。
如果history.action
等于'POP'
,则按下后退按钮。否则为'PUSH'
。
详细答案:
我可以通过以下方式访问每页道具中的历史记录:
<Provider store = { store }>
<AppRouter />
</Provider>
AppRouter
在哪里:
import React from 'react';
import { Router, Route, Switch } from 'react-router-dom';
import createHistory from 'history/createBrowserHistory';
import PublicRoute from './PublicRoute';
import PageHome from '../pages/front/home/PageHome';
export const history = createHistory();
const AppRouter = () => (
<Router history={ history }>
<div>
<Switch>
<PublicRoute
exact = { true }
path = "/"
component = { PageHome }
history={ history }
/>
< ..... Other routes here ..... >
</Switch>
</div>
</Router>
);
export default AppRouter;
PublicRoute
组件是这样的:
import React from 'react';
import { Route } from 'react-router-dom';
import Header from '../components/header/Header';
const PublicRoute = ( { component: Component, ...rest } ) => (
<Route
component={ ( props ) => (
<div>
<Header />
<Component { ...props } />
</div>
)}
{ ...rest }
/>
);
export default PublicRoute;