Next.js 13 - Le hook useHydrateAtoms de Jotai provoque une incompatibilité de l'interface utilisateur
P粉548512637
2023-08-29 15:28:26
<p>Travailler avec les projets Next.js 13 en utilisant le nouveau catalogue d'applications et Jotai en tant que gestionnaire d'état global. Maintenant, j'essaie d'utiliser le hook <code>useHydrateAtoms</code> pour transmettre l'état initial à mes atomes comme indiqué dans la documentation officielle, mais cela entraîne une erreur d'hydratation. </p>
<p>Ce qui suit est une version simplifiée du code actuellement utilisé, qui transmet les données reçues du composant côté serveur au composant côté client qui appelle <code>useHydrateAtoms</code> useAtom</ code> Lire et écrire à partir de cet atome. </p>
<h5>Composant serveur (page)</h5>
<pre class="brush:php;toolbar:false;">const getData = async () =>
//...
}
exporter la fonction asynchrone par défaut Page() {
const data = attendre getData();
return <ChildComponent initialState={data} />;
}</pré>
<h5>Composant client</h5>
<pre class="brush:php;toolbar:false;">"utiliser le client";
fonction d'exportation ChildComponent({ initialState }) {
useHydrateAtoms([[myAtom, initialState]]);
const [data, setData] = useAtom(myAtom);
return <>{data.id}</>;
}</pré>
<p>L'erreur disparaît complètement lorsque j'importe dynamiquement le sous-composant à l'aide de <code>next/dynamic</code> et que je définis l'option SSR sur false ou que je supprime le hook <code>useHydrateAtoms</code> les solutions vont à l’encontre du but de cette implémentation. </p>
<p>Comment puis-je fournir un état initial à mon atome en utilisant une valeur du serveur afin que l'atome ne soit pas <code>null</code> lors du premier rendu client ? </p>
J'ai découvert
useHydrateAtoms
钩子本身并不是问题,它是一个客户端组件,它访问通过 next/dynamic 动态导入的 UI 不同部分的状态ssr
选项设置为false
. Cela entraîne une modification de la valeur affichée par le composant lors du premier rendu, ce qui entraîne une incompatibilité de l'interface utilisateur.Comment corriger les erreurs
Déplacez simplement le composant appelant
useHydrateAtoms
en haut de l'arborescence des composants, cela garantira que tous les composants enfants seront rendus avec les valeurs correctes.