首頁 > web前端 > js教程 > 為什麼我在 ReactJS 應用程式中收到「元件正在更改要控制的文字類型的不受控制的輸入」警告?

為什麼我在 ReactJS 應用程式中收到「元件正在更改要控制的文字類型的不受控制的輸入」警告?

Mary-Kate Olsen
發布: 2024-10-28 12:43:01
原創
462 人瀏覽過

Why am I getting the

不受控制和受控制的輸入元素:ReactJS 警告指南

ReactJS 建議保持輸入元素控制狀態的一致性。在某些情況下,您可能會遇到警告:「元件正在更改要控制的文字類型的不受控制的輸入。」讓我們深入探討原因並探索有效的解決方案。

問題根源

在 ReactJS 中,輸入元素可以是受控的,也可以是不受控的。受控輸入是其值由元件狀態管理的輸入,而非受控輸入允許使用者直接變更其值。當最初聲明為不受控的輸入後來轉換為受控輸入時,就會出現問題。

考慮以下程式碼:

<br>class MyComponent extends React.Component {<br> 建構子(props) {<pre class="brush:php;toolbar:false">super(props);
this.state = {
  fields: {}
}
登入後複製

}

onChange(field, e){

let fields = this.state.fields;
fields[field] = e.target.value;
this.setState({fields});
登入後複製

}

render() {

return(
  <div>
    <input
      value={this.state.fields["name"]}
      onChange={this.onChange.bind(this, "name")}
      type="text"
      placeholder="Name *"
    />
  </div>
)
登入後複製

}
}

}

}

pre>

在此範例中,「name」輸入不受控制,因為其值最初未定義(this.state. fields["name"]),允許使用者自由變更。但是,當使用者輸入值時,onChange 處理程序會設定 this.state.fields.name,有效地將輸入轉換為受控狀態。此狀態轉換會觸發警告。

    解決問題

  1. 要解決警告,您可以:

    <code class="python">class MyComponent extends React.Component {
      constructor(props) {
     super(props);
     this.state = {
       fields: {
         name: '',
       }
     }
      }
    
      // ...
    }</code>
    登入後複製
  2. 定義狀態中的初始欄位:
  3. 為每個欄位宣告this.state.fields 並使用空字串。這確保了所有輸入最初都受到控制。

    <code class="python">value={this.state.fields.name || ''}</code>
    登入後複製
  4. 使用短路評估:
使用短路評估來指派 value 屬性,這確保未定義值的計算結果為空字串。

透過實作任一解決方案,您都可以消除錯誤並確保輸入控制狀態的一致性。

以上是為什麼我在 ReactJS 應用程式中收到「元件正在更改要控制的文字類型的不受控制的輸入」警告?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板