[解決済み] 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では、このようなエラーが発生するのかもしれません。
関連
-
[解決済み】node.js TypeError: path must be absolute or specify root to res.sendFile [JSONのパースに失敗しました]。
-
[解決済み】フォームコントロールの値アクセサがない
-
[解決済み】JavaScriptで':'(コロン)は何をするのか?
-
[解決済み】Angular JS Uncaught Error。[インジェクター:モジュラー]。
-
[解決済み】NodeJS "ESモジュールをロードするためにインポートを使用する必要があります。"
-
[解決済み] React with ES7: Uncaught TypeError: Cannot read property 'state' of undefined [duplicate] (未定義のプロパティ'state'を読み込むことはできません。
-
[解決済み】SyntaxError: 'import' と 'export' は 'sourceType: module' とだけ表示されるかもしれない - Gulp
-
[解決済み】 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.
-
[解決済み】Jestが予期しないトークンに遭遇した
-
[解決済み] Uncaught (in promise) TypeError: フェッチに失敗してCorsエラー
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】パッシブイベントリスナー内部でpreventDefaultができない
-
[解決済み] Uncaught TypeError: 未定義のプロパティ 'top' を読み込めない
-
[解決済み】JavaScriptのisset()に相当するもの
-
[解決済み】JavaScriptのボタンonclickが機能しない
-
[解決済み】JS ファイルが net::ERR_ABORTED 404 (Not Found) を取得する)
-
[解決済み】JavaScriptで相対URLへのリダイレクトを行う
-
[解決済み】Vueのテンプレートまたはレンダー関数が定義されていない 私はどちらも使っていないのですが?
-
[解決済み】Jestが予期しないトークンに遭遇した
-
[解決済み】Uncaught TypeError: 未定義のプロパティ 'msie' を読み取れない - jQuery tools
-
[解決済み】module.exports "モジュールが定義されていません"