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

以下是我的代码:

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

当前回答

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

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

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

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

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

其他回答

虽然这听起来很疯狂,但为我解决这个问题的方法是添加一个额外的div

  ... [Other code] ...
  const [brokerLink, setBrokerLink] = useState('');
  ... [Other code] ...

  return (
    ... [Other code] ...
              <div styleName="advanced-form" style={{ margin: '0 auto', }}>
                {/* NOTE: This div */}
                <div>
                  <div styleName="form-field">
                    <div>Broker Link</div>
                    <input
                      type="text"
                      name="brokerLink"
                      value={brokerLink}
                      placeholder=""
                      onChange={e => setBrokerLink(e.target.value)}
                    />
                  </div>
                </div>
              </div>
    ... [Other code] ...
  );
... [Other code] ...

很奇怪。如果没有这个额外的div,由于某种原因,看起来react最初呈现的输入元素没有value属性,而是带有一个空的style属性。你可以通过查看html看到这一点。这导致了控制台警告。。

更奇怪的是,添加一个非空字符串的默认值或执行类似value={brokerLink||''}的操作将导致完全相同的问题。。

另一个奇怪的是,我还有30个几乎完全相同的元素,但没有引起这个问题。唯一不同的是,这个brokerLink没有外部分区。。并将其移动到代码的其他部分而不更改任何内容,从而出于某种原因删除了警告。。

如果没有我的精确代码,可能几乎不可能复制。如果这不是react中的bug,我不知道是什么。

我也面临同样的问题。在我的例子中,解决方案是我错过了向元素添加“name”属性。

<div className="col-12">
   <label htmlFor="username" className="form-label">Username</label>
        <div className="input-group has-validation">
             <span className="input-group-text">@</span>
                  <input 
                      type="text" 
                      className="form-control" 
                      id="username"
                      placeholder="Username" 
                      required=""
                      value={values.username}
                      onChange={handleChange}
                  />
                  <div className="invalid-feedback">
                      Your username is required.
                  </div>
        </div>
</div>

在我在属性的输入列表中引入name=username之后,效果很好。

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

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

发生这种情况是因为该值不能为未定义或null来解析。您可以这样做

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

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

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

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

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

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