reactjs - Redux getState 在行动中不起作用

标签 reactjs react-native redux redux-thunk

我对 redux 中的 getState() 有点困惑。我正在使用 thunk 中间件。

我有一个身份验证操作,它是一个异步操作。但是我有一个在其之前运行的操作,它检查状态中是否存在 token 以及它是否仍然有效。

我的问题是调用操作后似乎无法检查状态。以为我可以只使用 getState 但这似乎不是一个函数。

容器.js

componentDidMount() {
  this.props.authCheck()
}
...
function mapDispatchToProps(dispatch) {
  return {
    authCheck: () => checkApiStatus()(dispatch)
  }
}

Action .js

export const checkApiStatus = () => (dispatch, getState) => {
  const expires_at = getState().api.expires_at
  if (!expires_at || isDateGreater(expires_at)) {
    // dispatch async action
    dispatch(apiAuth())
  }
  return
}

任何人都有任何想法。或者也许更好的方式来实现这样的事情?

谢谢

最佳答案

问题是您在 mapDispatchToProps 方法中显式调用返回的函数并仅传递一个参数。而是调用 dispatch(checkApiStatus()) 然后 redux-thunk 将负责将正确的参数传递给返回的方法。应该是这样的

function mapDispatchToProps(dispatch) {
  return {
    authCheck: () => dispatch(checkApiStatus())
  }
}

关于reactjs - Redux getState 在行动中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49713511/

相关文章:

reactjs - 如何访问 React Material-UI 主要和次要颜色的明暗变体?

react-native - 如何在 native react 中打印屏幕内容?

javascript - Flux 架构比 MVC 有何优势

reactjs - 如何将 redux-persist 与自定义中间件一起使用

javascript - 我无法通过在React Native中单击redux来从FlatList中一一删除项目

javascript - 将 create-react-app 构建版本部署到 Heroku

javascript - 如何从 C# 服务器中的 POST(或其他 HTTP)请求访问参数?

javascript - ACE 编辑器自动完成打开 `.`

ios - AlertIOS.prompt for numeric 输入

react-native - ReactNative/MobX : How to access component refs from MobX?