redux-thunk中使用ts异步action如何做类型推断

新手上路,请多包涵
export interface DelUserInfoAction {
  type: typeof DEL_USER_INFO
}
export type UserInfoActionTypes =  DelUserInfoAction 

export function userInfoReducer(state = initUserState, action: UserInfoActionTypes): iUserInfoState {
  switch (action.type) {
    case DEL_USER_INFO:
      return { ...initUserState }
    default:
      return state
  }
}


// action
export function deleteUserInfo(): UserInfoActionTypes {
  return {
    type: DEL_USER_INFO
  }
}

export const asyncLogout = ():ThunkAction<void, RootState, null, Action<string>> => async (dispatch) => {
  await apiLogout()
  dispatch(deleteUserInfo())
}

// 组件中
const btnClick = () => {
    store.dispatch(asyncLogout)
}
// 报错
Argument of type 'ThunkAction<void, CombinedState<{ user: iUserInfoState; }>, null, Action<DelUserInfoAction>>' is not assignable to parameter of type 'AnyAction'.
阅读 1.8k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题