[react] 优雅解决typescript动态获取redux仓库的类型问题

store.getState()是可以获取总仓库的

先拿到函数的类型

再用ReturnType<T>

它是 TypeScript 中的一个内置条件类型,用于获取某个函数类型 T 的返回值类型

代码

javascript 复制代码
    // 先拿总仓库的函数类型
    type StatefuncType = typeof store.getState;
    //再拿函数类型T的返回值类型
    type StateType = ReturnType<StatefuncType>;
    const counter = useSelector((state: StateType) => {
        return state.couterSlice;
    });

可以直接一步到位

javascript 复制代码
    type StateType = ReturnType<typeof store.getState>;

也可以用这样

javascript 复制代码
const a = store.getState();
    type a1 = typeof a;

还麻烦怎么办?我想在导入的时候自带类型呢?

用TypedUseSelectorHook 加自定义useSelector

参考:TypeScript 快速开始 | Redux 中文官网

javascript 复制代码
import { configureStore } from '@reduxjs/toolkit';
import { useSelector, TypedUseSelectorHook } from 'react-redux';
import couterSlice from './modules/counter';

const store = configureStore({
    reducer: {
        couterSlice,
    },
});
export type storeType = ReturnType<typeof store.getState>;

export const useAppSelector: TypedUseSelectorHook<storeType> = useSelector;
export default store;
相关推荐
似水流年QC2 分钟前
前端国际化实战指南:i18n 工程化最佳实践总结
前端
GISer_Jing3 分钟前
企业级前端脚手架:原理与实战指南
前端·前端框架
非凡ghost8 分钟前
Floorp Browser(基于Firefox火狐浏览器)
前端·windows·学习·firefox·软件需求
hpz122310 分钟前
XHR和Fetch功能对比表格
前端·网络请求
我是小邵16 分钟前
【踩坑实录】一次 H5 页面在 PC 端的滚动条与轮播图修复全过程(Vue + Vant)
前端·javascript·vue.js
苹果电脑的鑫鑫21 分钟前
Css画圆弧的方法
前端·css
借个火er31 分钟前
Vue.js 源码揭秘(一):Vue3 架构总览
前端
千寻girling33 分钟前
面试官: “ 请你说一下什么是 ajax ? ”
前端·javascript
MQliferecord37 分钟前
webpack的生命周期与Loader/Plugin
前端
@大迁世界41 分钟前
JavaScript 框架的终结
开发语言·前端·javascript·ecmascript