React Router - 如何确定是否按下后退按钮?

时间:2017-01-25 22:32:23

标签: reactjs react-router

我有这些场景

设置页面 - >结果页面 - >详情页面

用户选择设置,点击下一步,获取结果,然后点击更多详细信息。

详细信息页面 - >结果页面

用户从详细信息页面返回结果页面。这导致完全重新渲染,导致我再次无法点击服务器(我将结果存储在数组中)。

详细信息页面 - >结果页面 - >设置页面 - >结果页面

用户转到详细信息,然后返回结果(想要获取存储的结果),然后返回设置页面,进行更改然后返回到结果页面(现在我想再次从服务器获取完整的数据)。< / p>

我想知道是否存在反应路由器,以确定我是否通过浏览器历史记录来到该页面,或者我是否正在进行前进动作。

2 个答案:

答案 0 :(得分:1)

在React Router中,如果路由器调用该组件的子路径,则组件将保持挂载状态。因此,在您的示例中,您可以执行以下操作:

<Route path="items" component={Results}>
    <Route path=":id" component={Detail} />
</Route>

这样,Results组件在安装Detail组件时无法卸载,因为DetailResults的子组件。但是,如果您不希望在详细信息中看到结果组件被渲染,则只能在它们存在时进行渲染。如下所示:

 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;