我刚开始学习TypeScript,遇到了这个错误:
Overload 1 of 3,
(thunkAction: ThunkAction<unknown, { globalState: State; }, unknown, ActionsTypes>): unknown
, gave the following error.
Argument of type
{ type: string; payload: { titlle: string; }; }
is not assignable to parameter of type
ThunkAction<unknown, { globalState: State; }, unknown, ActionsTypes>
Type
{ type: string; payload: { titlle: string; }; }
provides no match for the signature
(dispatch: ThunkDispatch<{ globalState: State; }, unknown, ActionsTypes>, getState: () => { globalState: State; }, extraArgument: unknown): unknown
Overload 2 of 3, (action: ActionsTypes): ActionsTypes, gave the following error.
Argument of type
{ type: string; payload: { titlle: string; }; }
is not assignable to parameter of type ActionsTypes
Type
{ type: string; payload: { titlle: string; }; }
is not assignable to type setActiveNoteType
Types of property type are incompatible.
Type string is not assignable to type "SETACTIVEFRAME"
Overload 3 of 3,
(action: ActionsTypes | ThunkAction<unknown, { globalState: State; }, unknown, ActionsTypes>): unknown
, gave the following error.
Argument of type
{ type: string; payload: { titlle: string; }; }
is not assignable to parameter of type
ActionsTypes | ThunkAction<unknown, { globalState: State; }, unknown, ActionsTypes>
Type
{ type: string; payload: { titlle: string; }; }
is not assignable to type setActiveNoteType
这是我的 React 应用程序的减速器代码:
import { ThunkAction } from 'redux-thunk'
import { ThunkDispatch } from 'redux-thunk'
import { StateType } from "./Redux-store";
type Frame = {
titlle: string;
text: string | null;
};
export type State = {
frames: Frame[];
isCreateBlank: boolean;
activeFrame: number;
};
export const setFrame = (titlle: string) => ({ type: 'SETFRAME', payload: { titlle } });
export const isCreateBlankFalse = () => ({ type: 'ISCREATEBLANKFALSE' });
export const isCreateBlankTrue = () => ({ type: 'ISCREATEBLANKTRUE' });
export const setActiveNote = (id: number) => ({ type: 'SETACTIVEFRAME', payload: { id } });
type setFrameActionType = {
type: 'SETFRAME';
payload: { titlle: string };
};
type setActiveNoteType = {
type: 'SETACTIVEFRAME';
payload: { id: number };
};
type isCreateBlankType = {
type: 'ISCREATEBLANKFALSE' | 'ISCREATEBLANKTRUE';
};
export let initialState: State = {
frames: [],
isCreateBlank: false,
activeFrame: 0
};
export type ActionsTypes = setFrameActionType | isCreateBlankType | setActiveNoteType;
export let globalReduser = (state: State = initialState, action: ActionsTypes): State => {
switch (action.type) {
case "SETFRAME":
return {
...state,
frames: [...state.frames, { titlle: action.payload.titlle, text: null }]
};
case "ISCREATEBLANKFALSE":
return {
...state,
isCreateBlank: false
};
case "SETACTIVEFRAME":
return {
...state,
activeFrame: action.payload.id
};
case "ISCREATEBLANKTRUE":
return {
...state,
isCreateBlank: true
};
default:
return state;
}
};
export type ThunkSetFrameType = ThunkAction<Promise<void>, StateType, unknown, ActionsTypes>;
export type AppDispatch = ThunkDispatch<StateType, unknown, ActionsTypes>;
export const setFrameThunk = (titlle: string): ThunkSetFrameType => {
return async (dispatch: AppDispatch, getState: () => StateType) => {
dispatch(setFrame(titlle));
dispatch(isCreateBlankFalse());
};
};
这是 Redux-Store.ts 代码:
import { configureStore, combineReducers } from "@reduxjs/toolkit"
import { globalReduser } from "../Redux/GReduser"
let reducers = combineReducers({
globalState: globalReduser
})
export let store = configureStore({reducer: reducers})
export type DispatchType = typeof store.dispatch
export type StateType = ReturnType<typeof store.getState>
我不明白这里出了什么问题