[解決済み] Uncaught Invariant Violation(捕らえられない不変量違反)。前のレンダリング時よりも多くのフックをレンダリングした
質問
次のようなコンポーネントがあります(非常に単純化されたバージョン)。
const component = (props: PropTypes) => {
const [allResultsVisible, setAllResultsVisible] = useState(false);
const renderResults = () => {
return (
<section>
<p onClick={ setAllResultsVisible(!allResultsVisible) }>
More results v
</p>
{
allResultsVisible &&
<section className="entity-block--hidden-results">
...
</section>
}
</section>
);
};
return <div>{ renderResults() }</div>;
}
このコンポーネントが使用されているページを読み込むと、このようなエラーが発生します。
Uncaught Invariant Violation: Rendered more hooks than during the previous render.
このエラーの説明を探したのですが、検索しても結果が出ません。
コンポーネントを少し修正した場合。
const component = (props: PropTypes) => {
const [allResultsVisible, setAllResultsVisible] = useState(false);
const handleToggle = () => {
setAllResultsVisible(!allResultsVisible);
}
const renderResults = () => {
return (
<section>
<p onClick={ handleToggle }>
More results v
</p>
{
allResultsVisible &&
<section className="entity-block--hidden-results">
...
</section>
}
</section>
);
};
return <div>{ renderResults() }</div>;
}
そのエラーは出なくなりました。それは、私が
setState
が返す jsx 内の関数です。
renderResults
? なぜその修正が効くのかの説明があると嬉しいです。
解決方法は?
この修正は、最初のコードサンプル(エラーのあるもの)が
onClick
一方、2番目(正常に動作するもの)は、関数を
onClick
. この違いは、JavaScriptでは「このコードを実行する」という意味を持つ、重要な括弧の違いです。
最初のサンプルコードでは、毎回
component
がレンダリングされます。
renderResults
が呼び出されます。そのたびに
setAllResultsVisible(!allResultsVisible)
が、クリックを待つのではなく、呼び出されます。Reactは独自のスケジュールでレンダーを実行するため、これが何回起こるかはわかりません。
Reactのドキュメントより。
JSXでは、イベントハンドラとして、文字列ではなく、関数を渡します。
注:最初のコードサンプルをサンドボックスで実行しても、この正確なエラーメッセージを得ることはできませんでした。私のエラーは、無限ループを指していました。もしかしたら、より新しいバージョンのReactでは、このようなエラーが発生するのかもしれません。
関連
-
[解決済み】Facebook Graph API のクエリで with=location を使用すると "Uncaught (in promise) undefined" というエラーが発生する。
-
[解決済み】TypeError: $(...).DataTable は関数ではありません。
-
[解決済み】Uncaught ReferenceError。Reactが定義されていない
-
[解決済み] テスト
-
[解決済み】React、Uncaught ReferenceError。ReactDOMは定義されていません
-
[解決済み】Uncaught SyntaxError: JSON の位置 0 に予期しないトークン u があります。
-
[解決済み】 Uncaught Error: Invariant Violation: 解決済み】 Uncaught Error: Invariant Violation: Element type is invalid: expected a string (for built-in components) or a class/function but got: object.
-
[解決済み】リソースはドキュメントと解釈されるが、MIMEタイプはapplication/zipで転送される
-
[解決済み】Javascript、[オブジェクトHTMLInputElement]を表示中。]
-
[解決済み】中央値の計算 - javascript
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】フォームコントロールの値アクセサがない
-
[解決済み】Angular JS Uncaught Error。[インジェクター:モジュラー]。
-
[解決済み] 解決済み】clearInterval()が動作しない [重複] [重複]
-
[解決済み】XMLHttpRequestモジュールが定義されていない/見つからない
-
[解決済み] テスト
-
[解決済み】JavaScriptで相対URLへのリダイレクトを行う
-
[解決済み】Vueのテンプレートまたはレンダー関数が定義されていない 私はどちらも使っていないのですが?
-
[解決済み】Jestが予期しないトークンに遭遇した
-
[解決済み】Syntax error: JavaScriptの不正なreturnステートメント
-
[解決済み】Javascript、[オブジェクトHTMLInputElement]を表示中。]