Maison >interface Web >js tutoriel >React v La version stable et les nouveautés

React v La version stable et les nouveautés

Linda Hamilton
Linda Hamiltonoriginal
2024-12-09 00:12:12847parcourir

React v The Stable Release and What’s New

React 19 est officiellement arrivé, apportant une multitude de nouvelles fonctionnalités et améliorations qui simplifient le développement et améliorent les performances des applications. De la gestion améliorée des états à une meilleure intégration côté serveur, React 19 a quelque chose pour tout le monde.


Principales fonctionnalités de React 19 :

1. Actions pour une gestion simplifiée de l'état asynchrone

La gestion des opérations asynchrones telles que les requêtes API a toujours été un défi courant dans React. React 19 introduit les Actions, qui automatisent les états en attente, la gestion des erreurs et les mises à jour optimistes.

Exemple : Soumission de formulaire simplifié avec

Actions

import { useActionState } from "react";

function UpdateNameForm() {
  const [error, submitAction, isPending] = useActionState(
    async (prevState, formData) => {
      const name = formData.get("name");
      const error = await updateName(name);
      if (error) {
        return error;
      }
      redirect("/profile");
      return null;
    },
    null
  );

  return (
    <form action={submitAction}>
      <input type="text" name="name" />
      <button type="submit" disabled={isPending}>
        Update
      </button>
      {error && <p>{error}</p>}
    </form>
  );
}

Ici, useActionState gère l'état de soumission et la gestion des erreurs pour vous, rendant le code plus propre et plus facile à maintenir.


2. Mises à jour optimistes avec useOptimistic

Les mises à jour optimistes de l'interface utilisateur permettent aux utilisateurs de voir immédiatement les modifications lorsqu'une requête asynchrone est en cours. Le nouveau hook useOptimistic rend ce modèle simple.

Exemple : changement de nom optimiste

import { useOptimistic } from "react";

function ChangeName({ currentName, onUpdateName }) {
  const [optimisticName, setOptimisticName] = useOptimistic(currentName);

  const submitAction = async (formData) => {
    const newName = formData.get("name");
    setOptimisticName(newName); // Show optimistic state
    const updatedName = await updateName(newName); // Wait for the async request
    onUpdateName(updatedName); // Update the actual state
  };

  return (
    <form action={submitAction}>
      <p>Your name: {optimisticName}</p>
      <input type="text" name="name" />
      <button type="submit">Change Name</button>
    </form>
  );
}

useOptimistic garantit une expérience utilisateur transparente en affichant les mises à jour avant même que le serveur ne réponde.


3. Rapport d'erreur amélioré pour les inadéquations d'hydratation

React 19 améliore la gestion des erreurs, notamment pour les erreurs d'hydratation. Au lieu de vagues erreurs, vous obtenez désormais des différences détaillées de contenu incompatible entre le serveur et le client.

Exemple : Diff d'erreur d'hydratation

Uncaught Error: Hydration failed because the server-rendered HTML didn’t match the client.
Tree mismatch:
+ Client: <span>Welcome</span>
- Server: <span>Hello</span>

Ces messages clairs aident les développeurs à déboguer les problèmes rapidement et efficacement.


4. Composants du serveur et actions du serveur

Les composants React Server (RSC) permettent de restituer les composants sur le serveur, améliorant ainsi les performances. Les actions du serveur permettent d'appeler des fonctions asynchrones sur le serveur directement à partir des composants clients.

Exemple : Utilisation des actions du serveur

// Server Component
export const fetchComments = async () => {
  const response = await fetch("/api/comments");
  return await response.json();
};

// Client Component
import { use } from "react";

function Comments({ commentsPromise }) {
  const comments = use(commentsPromise); // Suspends until resolved
  return (
    <ul>
      {comments.map((comment) => (
        <li key={comment.id}>{comment.text}</li>
      ))}
    </ul>
  );
}

// Usage
function App() {
  return (
    <Suspense fallback={<p>Loading comments...</p>}>
      <Comments commentsPromise={fetchComments()} />
    </Suspense>
  );
}

Les actions serveur rationalisent la récupération et le rendu des données côté serveur dans les composants clients.


5. Gestion native des métadonnées et des feuilles de style

React 19 prend désormais en charge , <link> et <meta> balises nativement, simplifiant la gestion des métadonnées des documents.</p> <p><strong>Exemple : Métadonnées dynamiques dans les composants</strong><br> </p> <pre class="brush:php;toolbar:false">function BlogPost({ title, keywords }) { return ( <article> <h1>{title}</h1> <title>{title}</title> <meta name="keywords" content={keywords.join(", ")} /> <p>Content of the blog post...</p> </article> ); } </pre> <p>React garantit que ces balises sont rendues dans le fichier <head> section automatiquement, améliorant le référencement et la convivialité.</p> <p><strong>Exemple : Feuilles de style gérées</strong><br> </p> <pre class="brush:php;toolbar:false">import { useActionState } from "react"; function UpdateNameForm() { const [error, submitAction, isPending] = useActionState( async (prevState, formData) => { const name = formData.get("name"); const error = await updateName(name); if (error) { return error; } redirect("/profile"); return null; }, null ); return ( <form action={submitAction}> <input type="text" name="name" /> <button type="submit" disabled={isPending}> Update </button> {error && <p>{error}</p>} </form> ); } </pre> <p>React garantit que les feuilles de style sont chargées dans le bon ordre et une seule fois, même lorsqu'elles sont référencées plusieurs fois.</p> <hr> <h3> <strong>Pourquoi passer à React 19 ?</strong> </h3> <p>Les nouvelles fonctionnalités de React 19 réduisent considérablement le code passe-partout, améliorent les performances des applications et améliorent l'expérience de développement. Des fonctionnalités telles que <strong>Actions</strong>, <strong>Mises à jour optimistes</strong> et <strong>Composants de serveur</strong> permettent aux développeurs de créer des applications dynamiques, réactives et évolutives avec moins d'effort.</p> <hr> <h3> <strong>Comment mettre à niveau</strong> </h3> <p>Suivez le guide de mise à niveau React 19 pour une transition en douceur. Assurez-vous de tester minutieusement et de corriger toute modification importante décrite dans le guide.</p> <hr> <p>React 19 change la donne, alliant simplicité, puissance et performances. Commencez à expérimenter ces nouvelles fonctionnalités et élevez vos projets React au niveau supérieur !</p> <p>Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!</p></div><div class="nphpQianMsg"><a href="javascript:void(0);">less</a> <a href="javascript:void(0);">for</a> <a href="javascript:void(0);">while</a> <a href="javascript:void(0);">Error</a> <a href="javascript:void(0);">using</a> <a href="javascript:void(0);">this</a> <a href="javascript:void(0);">transition</a> <a href="javascript:void(0);">ui</a> <a href="javascript:void(0);">SEO</a> <a href="javascript:void(0);">Game</a><div class="clear"></div></div><div class="nphpQianSheng"><span>Déclaration:</span><div>Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn</div></div></div><div class="nphpSytBox"><span>Article précédent:<a class="dBlack" title="Comment puis-je geler les en-têtes de tableaux HTML à l’aide de CSS et JavaScript ?" href="https://m.php.cn/fr/faq/1796713282.html">Comment puis-je geler les en-têtes de tableaux HTML à l’aide de CSS et JavaScript ?</a></span><span>Article suivant:<a class="dBlack" title="Comment puis-je geler les en-têtes de tableaux HTML à l’aide de CSS et JavaScript ?" href="https://m.php.cn/fr/faq/1796713306.html">Comment puis-je geler les en-têtes de tableaux HTML à l’aide de CSS et JavaScript ?</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>Articles Liés</h2><em><a href="https://m.php.cn/fr/article.html" class="bBlack"><i>Voir plus</i><b></b></a></em><div class="clear"></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-6t+ed+2i-1n-4w" data-ad-client="ca-pub-5902227090019525" data-ad-slot="8966999616"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><ul class="nphpXgwzList"><li><b></b><a href="https://m.php.cn/fr/faq/1609.html" title="Une analyse approfondie du composant de groupe de liste Bootstrap" class="aBlack">Une analyse approfondie du composant de groupe de liste Bootstrap</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/fr/faq/1640.html" title="Explication détaillée du currying de la fonction JavaScript" class="aBlack">Explication détaillée du currying de la fonction JavaScript</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/fr/faq/1949.html" title="Exemple complet de génération de mot de passe JS et de détection de force (avec téléchargement du code source de démonstration)" class="aBlack">Exemple complet de génération de mot de passe JS et de détection de force (avec téléchargement du code source de démonstration)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/fr/faq/2248.html" title="Angularjs intègre l'interface utilisateur WeChat (weui)" class="aBlack">Angularjs intègre l'interface utilisateur WeChat (weui)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/fr/faq/2351.html" title="Comment basculer rapidement entre le chinois traditionnel et le chinois simplifié avec JavaScript et l'astuce permettant aux sites Web de prendre en charge le basculement entre les compétences en chinois simplifié et traditionnel_javascript" class="aBlack">Comment basculer rapidement entre le chinois traditionnel et le chinois simplifié avec JavaScript et l'astuce permettant aux sites Web de prendre en charge le basculement entre les compétences en chinois simplifié et traditionnel_javascript</a><div class="clear"></div></li></ul></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="autorelaxed" data-ad-client="ca-pub-5902227090019525" data-ad-slot="5027754603"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!</p></div><div class="footermid"><a href="https://m.php.cn/fr/about/us.html">À propos de nous</a><a href="https://m.php.cn/fr/about/disclaimer.html">Clause de non-responsabilité</a><a href="https://m.php.cn/fr/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body><!-- Matomo --><script> var _paq = window._paq = window._paq || []; /* tracker methods like "setCustomDimension" should be called before "trackPageView" */ _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u="https://tongji.php.cn/"; _paq.push(['setTrackerUrl', u+'matomo.php']); _paq.push(['setSiteId', '9']); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s); })(); </script><!-- End Matomo Code --></html>