当前位置: 首页 > news >正文

[react]redux异步处理和重写useDispatch

异步代码

import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
import { getBanner } from '../http/request';
import store from '@/store';
export const fetchBanner = createAsyncThunk('recommend/banners',async (args, thunkAPI) => {const response = await getBanner();thunkAPI.dispatch(getBannerAction(response.data));},
);
const recommendStore = createSlice({name: 'recommend',initialState: {banners: [],},reducers: {getBannerAction(state, { payload }) {console.log('得到', payload);state.banners = payload.banners;},},
});
export const { getBannerAction } = recommendStore.actions;
export default recommendStore.reducer;

外面调用的是

  dispatch(fetchBanner());

但是ts会报错

类型“AsyncThunkAction<any, void, AsyncThunkConfig>”的参数不能赋给类型“UnknownAction”的参数。ts

这时候来到总仓库 把  dispatch改装一下

// dispatch
export type AppDispatch = typeof store.dispatch;
export const useAppDispatch = () => useDispatch<AppDispatch>();

 或者

type AppDispatch = typeof store.dispatch;
export const useAppDispatch: () => AppDispatch = useDispatch;

外面就可以用了,ts不会报错了

    useEffect(() => {dispatch(fetchBanner());}, []);

http://www.lryc.cn/news/507140.html

相关文章:

  • 基础数据结构---栈
  • 【HarmonyOS之旅】DevEco Studio的安装与环境配置
  • Liveweb视频融合共享平台在果园农场等项目中的视频监控系统搭建方案
  • Android4.4 在系统中添加自己的System Service
  • 【C++】C++实现字符串大小写转换功能
  • 【蓝桥杯】43696.小数第n位
  • 进程间通信方式---消息队列(System V IPC)
  • windows10 安装wsl、迁移到其他盘
  • el-divide(vue3总)
  • python —— 常用命令行的命令
  • C++ 23版的最新特性
  • 什么是 Memory-bound stalls,以及如何优化
  • 机器学习 | 非线性回归拟合数据时的离群值检测
  • 使用elasticsearch-head插件修改elasticsearch数据
  • 202412月最新植物大战僵尸杂交版【V3.0.1】更新内容与下载
  • 游戏渠道假量解决方案
  • Java系统对接企业微信审批项目流程
  • 基于Springboot人口老龄化社区服务与管理平台【附源码】
  • Dot Foods EDI 需求分析及对接流程
  • 代码随想录day24 | leetcode 93.复原IP地址 90.子集 90.子集II
  • 探索国产数字隔离器——测试与应用
  • IDEA无法打开插件市场的解决
  • 以腾讯混元模型为例,在管理平台上集成一个智能助手
  • 15.初识接口1 C#
  • 探索 Python编程 调试案例:计算小程序中修复偶数的bug
  • 【Unity/HFSM】使用UnityHFSM实现输入缓冲(预输入)和打断机制
  • Unity 圆形循环复用滚动列表
  • 聚水潭数据无缝集成到金蝶云星空的实现方案
  • 虚拟机断网没有网络,需清理内存,删除后再重启
  • [c++11(二)]Lambda表达式和Function包装器及bind函数