微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

来自 Action Creator 的 history.push() 将更改 URL 但不会导航到页面

如何解决来自 Action Creator 的 history.push() 将更改 URL 但不会导航到页面

我有一个登录页面组件,我想在成功登录后从操作创建者 (thunk) 重定向。 它似乎有效,但当 URL 正确更改时,页面仍保留在登录页面上。

这里我导入了要在动作创建器中导入的历史记录:

// helpers/history.js
import { createbrowserHistory } from 'history';

const history = createbrowserHistory();

export default history;

这里是动作创建者的缩短版本:

// actions/session.js
import history from '../helpers/history';


export const login = (formData) => {
    return (dispatch) => {
        dispatch({type: LOGIN_REQUEST})
        return fetch("http://localhost:3001/login",{
...
       .then((user) => {
            history.push('/live-rewards')
            dispatch({
                type: LOGIN_REQUEST_SUCCESS
            })
        })
        .catch(err => {
...

这里是组件的缩短版本,用于显示如何调用登录和导入

// containers/LoginForm.js
import React,{ Component } from 'react'
import { connect } from "react-redux";
import { Link } from 'react-router-dom'
import { login } from '../actions/session'

class LoginForm extends Component {
...

    fetchOnSubmit = (e) => {
      e.preventDefault()
      this.props.login(this.state)
    }
...
const mapdispatchToProps = dispatch => {
  return {
    login: (credentials) => {
      return dispatch(login(credentials))
    }
  }
}

export default connect(mapStatetoProps,mapdispatchToProps)(LoginForm);

这里是如何实现 browserRouter 的:

// index.js
...
  <React.StrictMode>
    <Provider store={store}>
        <App />
    </Provider>
  </React.StrictMode>
...
// app.js
...
    <Router>
      <Navbar toggle={toggle} />
      <Sidebar isOpen={isOpen} toggle={toggle} />
      <Switch>
        <Route path='/live-rewards' component={Liverewards}/>
        <Route path='/signin' component={Signin}/>
        <Route path='/signup' component={Signup}/>
        <Route path='/' exact component={Home}/>
      </Switch>
    </Router>
...

解决方法

我建议您完全放弃此 history 对象,并从 BrowserRouter 上下文内的组件而不是通过操作创建者处理导航。

LoginForm 可以通过 withRouter 访问上下文 history 道具。它可以通过 isLoggedIn 传递 mapStateToProps 道具来访问状态中的凭据。

您的 render()LoginForm 方法将包含一个 Redirect 组件,该组件根据 isLoggedIn 属性有条件地呈现,当您 dispatch LOGIN_REQUEST_SUCCESS


不知何故从 state 映射到 boolean 道具 isLoggedIn。一个例子:

const mapStateToProps = (state) => ({
  isLoggedIn: !!state.credentials.token
})

条件渲染:

{this.props.isLoggedIn && <Redirect to="/live-rewards" />}

我更喜欢这种方法,因为这意味着如果用户已经登录,则根本无法加载登录页面。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?