警告:组件正在更改要控制的文本类型的非受控输入。输入元件不应从非受控切换到受控(反之亦然)。决定在部件的使用寿命内使用受控或非受控输入元件*

以下是我的代码:

constructor(props) {
  super(props);
  this.state = {
    fields: {},
    errors: {}
  }
  this.onSubmit = this.onSubmit.bind(this);
}

....

onChange(field, e){
  let fields = this.state.fields;
  fields[field] = e.target.value;
  this.setState({fields});
}

....

render() {
  return(
    <div className="form-group">
      <input
        value={this.state.fields["name"]}
        onChange={this.onChange.bind(this, "name")}
        className="form-control"
        type="text"
        refs="name"
        placeholder="Name *"
      />
      <span style={{color: "red"}}>{this.state.errors["name"]}</span>
    </div>
  )
}

当前回答

如果值不存在或为null,则放入空值。

value={ this.state.value || "" }

其他回答

首先设置当前状态。。。此状态

这是因为当您要分配一个新状态时,它可能是未定义的。因此,它也将通过设置状态提取当前状态来固定

this.setState({...this.state, field})

如果您的状态中有一个对象,则应按如下方式设置状态:,假设您必须在用户对象内设置用户名。

this.setState({user:{...this.state.user, ['username']: username}})

如果值不存在或为null,则放入空值。

value={ this.state.value || "" }

如上所述,您需要设置初始状态,在我的例子中,我忘记在setSate()中添加“”引号;

  const AddUser = (props) => {
  const [enteredUsername, setEnteredUsername] = useState()
  const [enteredAge, setEnteredAge] = useState()

出现以下错误

正确的代码是简单地将初始状态设置为空字符串“”

  const AddUser = (props) => {
  const [enteredUsername, setEnteredUsername] = useState('')
  const [enteredAge, setEnteredAge] = useState('')

使用React Hooks也不要忘记设置初始值。我使用的是<input-type='datetime-local'value={eventStart}/>,初始eventStart是这样的

const[eventStart,setEventStart]=useState();相反const[eventStart,setEventStart]=useState(“”);。

括号中的空字符串是差异。此外,若您像我一样在提交后重置表单,那个么再次需要将其设置为空字符串,而不仅仅是空括号。

这只是我对这个话题的一点小小贡献,也许会对某人有所帮助。

简单地说,您必须首先设置初始状态

如果不设置初始状态,react会将其视为不受控制的组件