React Typescript:'{ [x: number]: any; 类型的参数 }' 不能分配给类型的参数

IT技术 javascript reactjs typescript mobx
2021-05-07 21:30:35

我在我的项目(React、TS、Mobx)中添加了 onChange 方法,但出现错误: Argument of type '{ [x: number]: any; }' is not assignable to parameter of type

我是 TypeScript 的新手,不知道为什么会这样。可能是什么问题?

(parameter) event: {
    target: {
        name: any;
        value: any;
    };
}

'{ [x: number]: any; 类型的参数 }' 不可分配给类型为 'IAddPlayerFormState | 的参数 ((prevState: Readonly, props: Readonly) => IAddPlayerFormState | Pick | null) | 选择<...> | 空值'。

在此处输入图片说明

import React, { Component } from 'react';
import ViewStore from '../../../store/ViewStore';
import { TextField } from './../../../utils';

interface IAddPlayerFormProps {
  viewStore?: ViewStore; // Optional ViewStore
}

interface IAddPlayerFormState {
  playerName: string;
  isDisabled: boolean;
}

class AddPlayerForm extends Component<IAddPlayerFormProps, IAddPlayerFormState> {
  constructor(props: Readonly<IAddPlayerFormProps>) {
    super(props);

    this.state = {
      isDisabled: false,
      playerName: '',
    };
  }

  public onChange(event: { target: { name: any; value: any; }; }) {
    this.setState({ [event.target.name]: event.target.value });
    console.log('On Change!');
  }

  public handleSubmit = () => {
    console.log('On submit!');
  }

  public render() {
    const { isDisabled } = this.state;

    return (
      <form onSubmit={this.handleSubmit}>
        <TextField
          type="text"
          name="name"
          value={name}
          placeholder="Add player"
          onChange={this.onChange}
          disabled={isDisabled}
        />

        <input type="submit" />
      </form>
    );
  }
}

export default AddPlayerForm;
4个回答

您需要告诉 Typescript 您的对象将具有来自 IAddPlayerFormState 的一个或多个属性,但不一定是所有属性。你可以这样做:

public onChange(event: { target: { name: any; value: any; }; }) {
  const newState = { [name]: value } as Pick<IAddPlayerFormState, keyof IAddPlayerFormState>;
  this.setState(newState);
  console.log("On Change!");
}

使用此语法为我消除了错误:

const myFunction = (e) => {
    return this.setState({...this.state, [e.target.id]: e.target.value});
}

你的状态是这样的:

interface IAddPlayerFormState {
  playerName: string;
  isDisabled: boolean;
}

你用这个调用 setState :

{any: any}

您只能更改值:playerName 和 isDisabled 不是任何值。如果您将函数签名重写为

public onChange(event: { target: { name: "playerName"|"isDisabled"; value: any; }; })

或更好

public onChange(event: { target: { name: keyof IAddPlayerFormState ; value: any; }; })

typescript应该没问题。顺便说一句,此代码将不起作用。更改输入名称:)。我希望这个答案很清楚,如果不是,我会编辑它。

您需要做的就是指定要更新/更改的项目

this.setState({value:value});
type ItemState = {
    value?: string;// The state I want to update
};

#在你的情况下

this.setState({playerName : new_value});