ホームページ >ウェブフロントエンド >jsチュートリアル >**ReactJS の「コンポーネントが制御されていないタイプ テキストの入力を制御対象に変更しています」エラーを修正する方法?**
ReactJS: 「コンポーネントがテキスト型の制御されていない入力を制御されるように変更しています」エラー
ReactJS では制御されていない入力の処理に一貫性が必要ですおよび制御された入力要素。警告が示すように、コンポーネントの存続期間中、入力フィールドがこれら 2 つの状態の間で変動してはなりません。
問題の理解
提供されたコードでは、問題の原因は次のとおりです。状態の初期化。フィールドは最初に空のオブジェクト、つまりフィールド: {} として定義されます。この設定では、初期レンダリング時に入力要素を非制御入力として指定します。
ただし、入力フィールドに値が入力されると、状態のフィールド オブジェクトが更新され、制御された入力動作に切り替わります。非制御から制御へのこの移行は許可されていないため、警告が表示されます。
考えられる解決策
解決策 1: 空の文字列でフィールドを初期化する
状態の初期化を修正して名前フィールドに空の文字列を含め、入力が最初から制御されるようにします。
<code class="javascript">this.state = { fields: { name: '', }, errors: {}, };</code>
解決策 2: 短絡評価を実装する
状態のみに依存するのではなく、状態値が未定義の場合、短絡評価を使用して入力値を空の文字列として設定します。
<code class="javascript">value={this.state.fields.name || ''}</code>
これにより、次のことが保証されます。初期状態値が未定義であっても、入力フィールドは制御されたままになります。
これらの提案を実装すると、警告が解決され、入力が ReactJS の期待に従って一貫して処理されることが保証されます。
以上が**ReactJS の「コンポーネントが制御されていないタイプ テキストの入力を制御対象に変更しています」エラーを修正する方法?**の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。