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

以下是我的代码:

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>
  )
}

当前回答

除了接受的答案之外,如果您使用的是类型为checkbox或radio的输入,我发现我还需要null/undefined检查选中的属性。

<input
  id={myId}
  name={myName}
  type="checkbox" // or "radio"
  value={myStateValue || ''}
  checked={someBoolean ? someBoolean : false}
  />

如果您使用的是TS(或Babel),则可以使用零合并而不是逻辑or运算符:

value={myStateValue ?? ''}
checked={someBoolean ?? false}

其他回答

除了接受的答案之外,如果您使用的是类型为checkbox或radio的输入,我发现我还需要null/undefined检查选中的属性。

<input
  id={myId}
  name={myName}
  type="checkbox" // or "radio"
  value={myStateValue || ''}
  checked={someBoolean ? someBoolean : false}
  />

如果您使用的是TS(或Babel),则可以使用零合并而不是逻辑or运算符:

value={myStateValue ?? ''}
checked={someBoolean ?? false}

我使用react钩子遇到了同样的警告,尽管我之前已经将初始状态初始化为:-

const[post,setPost]=useState({title:“”,body:“”})

但后来我重写了onChange事件处理程序上预定义状态对象的一部分,

 const onChange=(e)=>{
        setPost({[e.target.name]:e.target.value})
    }

解决方案我通过首先处理前一状态的整个对象(通过使用扩展运算符),然后在其上进行编辑来解决这个问题,

 const onChange=(e)=>{
        setPost({...post,[e.target.name]:e.target.value})
    }

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

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

如果您正在将value属性设置为对象的属性,并希望确保该属性未定义,则可以组合空合并运算符??带有可选的链接运算符?。如下所示:

<input
  value={myObject?.property ?? ''}
/>

将值更改为defaultValue将解决该问题。

注:

defaultValue仅用于初始加载。如果要初始化输入,则应使用defaultValue,但如果要使用state更改值,则需要使用value。阅读此内容了解更多信息。

我在输入中使用了value={this.state.input ||“”}来消除该警告。