解决React中使用typescript报错,类型“DefaultRootState“上不存在属性“xxx“以及dispatch类型报错

使用redux后,在组件中通过useSelector(state=>state.xxx)拿数据的时候,就会报一个错误,内容就是 “类型"DefaultRootState"上不存在属性"xxx”"
在这里插入图片描述

解决

  • 使用store.getState获取到所有redux中的数据
  • TS中提供了 ReturnType , 用于 获取函数类型的返回值类型
  • 通过typeof将 反推出 获取到的数据类型,然后暴露出去使用

示例:

单独的声明一个 store.d.ts文件

import store from '@/store'

// Redux 应用的状态
export type RootState = ReturnType<typeof store.getState>

// ReturnType:thunk action 的返回类型,项目中几乎都是返回 Promise


这样子的话,在使用useSeletor获取数据,就不会报类型的错误了

import { RootState } from '@/store/types/store'
import { useSelector } from 'react-redux'

const xxx = useSelector((state: RootState) => state.xxxx)

解决使用 dispatch类型错误

使用redux-thunk后调用dispatch显示,没有指定dispatch的类型
在这里插入图片描述

解决

  • 使用redux-thunk中提空的ThunkAction方法
  • ThunkAction需要提供四个泛型类型变量参数

示例:

import { ThunkAction } from 'redux-thunk'

export type RootThunkAction = ThunkAction<void, RootState, unknown, RootAction>
  • RootAction为 相关的action类型声明
    例如:
// 项目中所有 action 的类型
// type RootAction = LoginAction | ProfileAction
export type RootAction = LoginAction | ProfileAction

export type ProfileAction =
  | {
      type: 'profile/fetchUser'
      payload: User
    }
  | {
      type: 'profile/fetchUserProfile'
      payload: UserProfile
    }

  • RootState为上面第一个问题中得到的类型

使用方式

在这里插入图片描述

  • 声明了RootAction后,使用dispatch就有了参数的提示,再也不会写错了
    在这里插入图片描述
  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值