<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Sadok Mhiri</title>
    <description>The latest articles on DEV Community by Sadok Mhiri (@sadokmhiri).</description>
    <link>https://dev.to/sadokmhiri</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F324654%2F4dd506fd-be76-44dc-ad26-d29057976a90.jpeg</url>
      <title>DEV Community: Sadok Mhiri</title>
      <link>https://dev.to/sadokmhiri</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/sadokmhiri"/>
    <language>en</language>
    <item>
      <title>Rafraîchir vos connaissances en Front-End</title>
      <dc:creator>Sadok Mhiri</dc:creator>
      <pubDate>Tue, 01 Feb 2022 15:28:07 +0000</pubDate>
      <link>https://dev.to/sadokmhiri/rafraichir-vos-connaissances-en-front-end-k20</link>
      <guid>https://dev.to/sadokmhiri/rafraichir-vos-connaissances-en-front-end-k20</guid>
      <description>&lt;p&gt;Je crée cet article afin de partager avec vous des connaissances que je les voit nécessaires pour un développeur front-end. En tant que développeur front-end j’ai commencé depuis quelques années mon parcours d'apprentissage ainsi le développement des projets clients au fur et à mesure. Durant toute ces années j’ai suivi des cours en lignes, des tutoriels, les documentations des différentes technologies avec lesquelles j’avais travaillé et je me trouve toujours avec un manque d’informations. Je partage avec vous quelques sources d’apprentissage dans lesquelles j’ai de la confiance et je vous garantie que vous n’allez jamais perdre votre temps en les suivant. &lt;a href="https://frontendmasters.com/"&gt;Frontendmasters&lt;/a&gt;, &lt;a href="http://freecodecamp.org"&gt;Freecodecamp&lt;/a&gt;, &lt;a href="https://www.pluralsight.com"&gt;Pluralsight&lt;/a&gt;, &lt;a href="https://www.udemy.com"&gt;Udemy&lt;/a&gt;.&lt;/p&gt;

&lt;h1&gt;
  
  
  JavaScript
&lt;/h1&gt;

&lt;p&gt;En tant que développeur web il est indispensable de connaître les bases du JavaScript ainsi que comprendre comment le JS Engine fonctionne derrière les coulisses:&lt;/p&gt;

&lt;p&gt;En JavaScript tout se passe dans un &lt;strong&gt;contexte d'exécution&lt;/strong&gt;. Vous pouvez supposer que ce contexte d'exécution est un gros conteneur, invoqué lorsque le JS engine commence à exécuter du code JavaScript. &lt;/p&gt;

&lt;p&gt;Dans ce conteneur, il y a principalement deux composants :&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Composant mémoire : Variable environment&lt;/li&gt;
&lt;li&gt;Composant du code : Execution thread&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--_gDqat4c--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2lilvschvsv52wbs8vv8.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--_gDqat4c--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2lilvschvsv52wbs8vv8.jpg" alt="Context d'exécution" width="461" height="405"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;JavaScript est un langage &lt;strong&gt;synchrone&lt;/strong&gt; à &lt;strong&gt;thread unique&lt;/strong&gt;. C'est parce qu'il ne peut exécuter qu'une commande à la fois et dans un ordre spécifique.&lt;/p&gt;

&lt;p&gt;Le moteur ( JS Engine) exécutera le code JavaScript en deux phases&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Phase de création de mémoire&lt;/li&gt;
&lt;li&gt;Phase d'exécution du code&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Dans la phase de création de mémoire, JavaScript parcourra tout le code et allouera de la mémoire à toutes les variables et fonctions du code. Pour les variables, JavaScript stockera &lt;strong&gt;undefined&lt;/strong&gt; dans la phase de création de la mémoire (uniquement avec les variables déclarées par le mot-clé &lt;strong&gt;VAR&lt;/strong&gt;), et pour les fonctions, il conservera l'intégralité du code de la fonction. ( Ce mécanisme est reconnu par le terme &lt;strong&gt;Hoisting&lt;/strong&gt; )&lt;/p&gt;

&lt;p&gt;Lorsque JavaScript exécute des fonctions, il crée un contexte d'exécution à l'intérieur du contexte d'exécution global.&lt;br&gt;
Une fois l'exécution des fonctions terminée, le moteur détruira son contexte d'exécution.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;function sum(a, b) {
    return a+b;
}

sum(4,5);
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--yEW181_P--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/539m0x9kjk4t2kps9ao5.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--yEW181_P--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/539m0x9kjk4t2kps9ao5.jpg" alt="Image description" width="827" height="462"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Une fois tout le code exécuté, le contexte d'exécution global sera également détruit, et C'est ainsi que JavaScript exécutera le code en arrière-plan.&lt;/p&gt;

&lt;h4&gt;
  
  
  Call Stack:
&lt;/h4&gt;

&lt;p&gt;On remarque de la section dernière que lorsqu'une fonction est invoquée en JavaScript, JavaScript crée son propre contexte d'exécution. &lt;/p&gt;

&lt;p&gt;Le contexte d'exécution devient compliqué à mesure que nous imbriquons des fonctions à l'intérieur d'une fonction.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--zebGjppR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ekqjk7ygnmpxq3q21wc5.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--zebGjppR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ekqjk7ygnmpxq3q21wc5.jpg" alt="Call Stack" width="673" height="501"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;JavaScript gère la création et la suppression du contexte d'exécution du code à l'aide de Call Stack.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--ukRB1jh5--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/bb9e1lu7udedqx707vqh.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--ukRB1jh5--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/bb9e1lu7udedqx707vqh.jpg" alt="Call Stack" width="258" height="549"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h4&gt;
  
  
  Hoisting:
&lt;/h4&gt;

&lt;p&gt;Vous pouvez trouver dans d'autres articles que « Hoisting » signifiant des variables physiquement déplacées vers le haut, on peut consacrer cette idée comme introduction mais réellement ce n'est pas vraiment ce qui se passe en fait.&lt;/p&gt;

&lt;p&gt;Lors de l’interprétation du code, le JS Engine passe par deux étapes:&lt;br&gt;
Phase de création ( Creation phase )&lt;br&gt;
Phase d’exécution ( Execution phase )&lt;/p&gt;

&lt;p&gt;Le JS Engine passe d'abord par le code dans la phase de création et alloue de l'espace mémoire pour les variables déclarées avec le mot-clé &lt;strong&gt;var&lt;/strong&gt;, il y a un autre joueur ici qui s'appelle &lt;strong&gt;l’Initializer&lt;/strong&gt;, qui est chargé d'initialiser leur valeur à &lt;strong&gt;undefined&lt;/strong&gt;.&lt;br&gt;
Les fonctions sont également prises en compte et le JS Engine alloue leur espace mémoire et le remplit par leur code durant cette phase.&lt;/p&gt;

&lt;p&gt;Dans la deuxième phase (phase d'exécution), le JS Engine parcourt le code et s'exécute.&lt;/p&gt;

&lt;p&gt;Pour la plupart des fonctionnalités ES6 (&lt;strong&gt;let&lt;/strong&gt;, &lt;strong&gt;const&lt;/strong&gt;, paramètres par défaut, etc.), la phase de création fonctionne tout à fait différemment. Il parcourt toujours le code et alloue de l'espace pour les variables, mais l’Initializer définit les variables avec un mode spécial appelé &lt;strong&gt;TDZ (Temporal Dead Zone)&lt;/strong&gt;, ce qui signifie que les variables existent mais que vous ne pouvez pas y accéder tant que vous n'avez pas affecté une valeur.&lt;/p&gt;

&lt;p&gt;Donc pour résumer:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt; Avec le mot-clé &lt;strong&gt;VAR&lt;/strong&gt; : la variable est déclarée ( espace mémoire alloué ) et initialisée par « &lt;strong&gt;undefined&lt;/strong&gt; »,&lt;/li&gt;
&lt;li&gt; Avec les fonctionnalités &lt;strong&gt;ES6 (LET)&lt;/strong&gt; : la variable est déclarée (espace mémoire alloué) et mise en mode &lt;strong&gt;TDZ&lt;/strong&gt; (vous ne pouvez pas y accéder tant que vous n'avez pas affecté une valeur)&lt;/li&gt;
&lt;li&gt;Vous pouvez accéder aux variables ( déclarées avec &lt;strong&gt;var&lt;/strong&gt; ) et fonctions même avant leur déclaration ( les fonctions sont stockées dans la mémoire avec leur code dans la phase de création ).&lt;/li&gt;
&lt;/ul&gt;
&lt;h4&gt;
  
  
  Closure:
&lt;/h4&gt;

&lt;p&gt;Signifie qu'une fonction interne a toujours accès aux variables et aux paramètres de sa fonction externe, même après le retour de la fonction externe.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;exemple de Closure:&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;prenons cette fonction:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const multiply = (num) =&amp;gt; {
    return (x) =&amp;gt; num * x;
}
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;cette fonction permet de multipier un nombre &lt;strong&gt;num&lt;/strong&gt; par un autre nombre &lt;strong&gt;x&lt;/strong&gt; en prenant &lt;strong&gt;num&lt;/strong&gt; en paramètre, et elle fait appel à une autre fonction en passant le paramètre &lt;strong&gt;x&lt;/strong&gt; afin de retourner le résultat: &lt;strong&gt;num * x&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;En déclarons les deux constantes suivantes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const double = multiply(2);
const triple = multiply(3);
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;double devient une référence à une fonction qui permet de prendre un nombre en paramètre et le multiplie par &lt;strong&gt;2&lt;/strong&gt; car &lt;strong&gt;multiply&lt;/strong&gt; est devenue une fonction qui retourne  &lt;strong&gt;(num * x)&lt;/strong&gt; dont &lt;strong&gt;num = 2&lt;/strong&gt; et &lt;strong&gt;x&lt;/strong&gt; est le nombre qui sera passé en paramètre lors de l'invocation de la fonction.&lt;/p&gt;

&lt;p&gt;triple devient une référence à une fonction qui permet de prendre un nombre en paramètre et le multiplie par 3  car triple est devenue une fonction qui retourne      &lt;strong&gt;(num * x) ** dont **num = 3&lt;/strong&gt; et &lt;strong&gt;x&lt;/strong&gt; est le nombre qui sera passé en paramètre lors de l'invocation de la fonction.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;double(10); // 20
triple(10); // 30
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h1&gt;
  
  
  DOM:
&lt;/h1&gt;

&lt;p&gt;Je crois que le &lt;strong&gt;DOM&lt;/strong&gt; pourrait être parmi les composants les plus essentiels du développement Web et que chaque développeur Front-end doit le comprendre convenablement.&lt;/p&gt;

&lt;p&gt;Le DOM n'est qu'une représentation arborescente de la page, nous partons de la balise HTML jusqu'au corps en passant par chaque élément individuel.&lt;/p&gt;

&lt;p&gt;Le navigateur nous donne l'&lt;strong&gt;API DOM&lt;/strong&gt; à laquelle on pouvait accéder en utilisant quelque chose comme &lt;strong&gt;innerHTML&lt;/strong&gt; ou &lt;strong&gt;getElementById&lt;/strong&gt;, cette API nous permet de traverser l'accès DOM à n'importe quel nœud que nous voulons, de les supprimer, d'ajouter un nouveau nœud, etc.&lt;br&gt;
Pour savoir plus sur le &lt;a href="https://developer.mozilla.org/fr/docs/Web/API/Document_Object_Model"&gt;DOM&lt;/a&gt;, je vous propose de visiter les URLs suivants: &lt;br&gt;
&lt;a href="https://dev.to/karaluton/what-exactly-is-the-dom-jhg"&gt;https://dev.to/karaluton/what-exactly-is-the-dom-jhg&lt;/a&gt;&lt;br&gt;
&lt;a href="https://htmldom.dev/"&gt;https://htmldom.dev/&lt;/a&gt;&lt;/p&gt;
&lt;h1&gt;
  
  
  CSSOM:
&lt;/h1&gt;

&lt;p&gt;Le &lt;strong&gt;DOM&lt;/strong&gt; contient tout le contenu de la page. Le &lt;strong&gt;CSSOM&lt;/strong&gt; contient tous les styles de la page, des informations sur la façon de styliser ce &lt;strong&gt;DOM&lt;/strong&gt;. &lt;strong&gt;CSSOM&lt;/strong&gt; est un peu similaire au DOM mais avec une petite différence, la construction &lt;strong&gt;DOM&lt;/strong&gt; est incrémentielle alors que le &lt;strong&gt;CSSOM&lt;/strong&gt; ne l'est pas car le navigateur bloque le rendu lors de cette phase,le rendu des pages est bloqué jusqu'à ce qu'il reçoive et traite tout le &lt;strong&gt;CSS&lt;/strong&gt; car les règles peuvent être écrasées, de sorte que le contenu ne peut pas être rendu tant que le &lt;strong&gt;CSSOM&lt;/strong&gt; n'est pas terminé.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;CSS&lt;/strong&gt; a son propre ensemble de règles pour identifier les jetons valides. N'oubliez pas que le C dans &lt;strong&gt;CSS&lt;/strong&gt; signifie 'Cascade'. Les règles &lt;strong&gt;CSS&lt;/strong&gt; tombent en cascade. Au fur et à mesure que l'analyseur convertit les jetons en nœuds, les descendants des nœuds héritent des styles. Les fonctionnalités de traitement incrémental ne s'appliquent pas à &lt;strong&gt;CSS&lt;/strong&gt; comme elles le font avec &lt;strong&gt;HTML&lt;/strong&gt;, car les règles suivantes peuvent remplacer les précédentes. Le modèle d'objet &lt;strong&gt;CSS&lt;/strong&gt; est construit au fur et à mesure que le &lt;strong&gt;CSS&lt;/strong&gt; est analysé, mais ne peut pas être utilisé pour créer l'arbre de rendu tant qu'il n'est pas complètement analysé, car les styles qui vont être écrasés par une analyse ultérieure ne doivent pas être affichés à l'écran.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--enXp1tcq--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/vozei1mcfalse3i002ks.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--enXp1tcq--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/vozei1mcfalse3i002ks.jpg" alt="Image description" width="584" height="822"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Si ce sujet vous intéresse, jetez un coup d'œil sur le &lt;a href="https://developer.mozilla.org/en-US/docs/Web/Performance/Critical_rendering_path"&gt;CRP ( Critical Rendering Path )&lt;/a&gt;.&lt;/p&gt;
&lt;h1&gt;
  
  
  CORS:
&lt;/h1&gt;

&lt;p&gt;&lt;strong&gt;CORS ( Cross Origin Resource Sharing )&lt;/strong&gt; est un mécanisme de sécurité implémenté par les navigateurs.&lt;br&gt;
Prenant cet URL: &lt;a href="https://www.exemple.com/home/index.html"&gt;https://www.exemple.com/home/index.html&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;l’Origin&lt;/strong&gt; de cet URL est: exemple.com&lt;/p&gt;

&lt;p&gt;Une &lt;strong&gt;requête Cross Origin&lt;/strong&gt; c’est quand un site web essaie de demander une ressource d’un URL avec un &lt;strong&gt;Origin&lt;/strong&gt; différent.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--xeNsWKtA--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/f9ip7376wjemnmse71pb.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--xeNsWKtA--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/f9ip7376wjemnmse71pb.png" alt="Image description" width="540" height="175"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Donc si ce site web &lt;strong&gt;exemple.com&lt;/strong&gt; essaie d’envoyer une requête à &lt;strong&gt;autreexemple.com&lt;/strong&gt; alors la requête est considérée comme une &lt;strong&gt;Cross Origin Request&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;CORS&lt;/strong&gt; intervient ici est offre la possibilité à &lt;strong&gt;autreexemple.com&lt;/strong&gt; de spécifier les &lt;strong&gt;Origins&lt;/strong&gt; qui seront autorisés à accéder à ses ressources. Tout cela est géré par l’utilisation des &lt;strong&gt;en-têtes HTTP:&lt;/strong&gt; &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;Access-Control-Allow-Origin: https://www.exemple.com&lt;/code&gt;
Pour que &lt;strong&gt;&lt;a href="http://www.exemple.com"&gt;www.exemple.com&lt;/a&gt;&lt;/strong&gt; soit le seul Origin qui peut y accéder.&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;Access-Control-Allow-Origin: *&lt;/code&gt; 
Pour que n’importe quel &lt;strong&gt;Origin&lt;/strong&gt; peut y accéder.&lt;/li&gt;
&lt;/ul&gt;
&lt;h1&gt;
  
  
  REST API:
&lt;/h1&gt;

&lt;p&gt;C’est une &lt;strong&gt;API ( Application Programming Interface )&lt;/strong&gt; qui utilise le style architectural &lt;strong&gt;REST ( Representational State Transfer )&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Ce style architectural permettant de fournir des normes entre les systèmes informatiques sur le web, facilitant ainsi la communication des systèmes entre eux. Les systèmes compatibles &lt;strong&gt;REST&lt;/strong&gt;, souvent appelés systèmes &lt;strong&gt;RESTful&lt;/strong&gt;. Parmi leurs caractéristiques, ils sont &lt;strong&gt;Stateless&lt;/strong&gt; car ils séparent la relation client / serveur. &lt;/p&gt;

&lt;p&gt;l'implémentation du client et l'implémentation du serveur peuvent se faire indépendamment sans que l'une se connaisse. Cela signifie que le code côté client peut être modifié à tout moment sans affecter le fonctionnement du serveur, et le code côté serveur peut être modifié sans affecter le fonctionnement du client.&lt;br&gt;
Ceci signifie qu’une &lt;strong&gt;API REST&lt;/strong&gt; peut être utilisée par plusieurs clients à la fois. On peut avoir par exemple une &lt;strong&gt;API REST&lt;/strong&gt; qui sert à servir un client WEB ( Application WEB ), et d’autres clients Mobile ( Application Android, Application IOS, etc. ). &lt;/p&gt;

&lt;p&gt;Pour qu’un client puisse se communiquer avec une &lt;strong&gt;API REST&lt;/strong&gt;, sa requête doit principalement contenir les éléments suivants: &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Méthode ( GET, POST, etc. )&lt;/li&gt;
&lt;li&gt;Path ( Endpoint )&lt;/li&gt;
&lt;li&gt;En-têtes HTTP ( HTTP headers )&lt;/li&gt;
&lt;li&gt;Corps ( Body ) ( Optionnel )&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Puisque les systèmes qui suivent le paradigme &lt;strong&gt;REST&lt;/strong&gt; sont &lt;strong&gt;Stateless&lt;/strong&gt;, ce qui signifie que le serveur n'a pas besoin de savoir dans quel état se trouve le client et vice versa. De cette façon, le serveur et le client peuvent comprendre n'importe quel message reçu, même sans voir les messages précédents.&lt;/p&gt;



&lt;p&gt;Après avoir parlé du Javascript, DOM et CSSOM et quelques autre notions basique pour un développeur front-end, passons maintenant à la section suivante de notre article qui se focalise sur l’utilisation du JavaScript notamment l’utilisation des frameworks/librairies afin de créer des applications web dynamiques, interactives et modernes.&lt;/p&gt;

&lt;p&gt;Dans cet article, j'ai choisi le framework &lt;a href="https://angular.io/"&gt;Angular&lt;/a&gt; créé et supporté par Google et la librairie &lt;a href="https://reactjs.org/"&gt;React.js&lt;/a&gt; créée et supportée par Facebook .&lt;/p&gt;
&lt;h1&gt;
  
  
  Angular
&lt;/h1&gt;

&lt;p&gt;Angular est un framework de développement Javascript permettant de créer des applications &lt;strong&gt;SPA&lt;/strong&gt; efficaces et sophistiquées. &lt;/p&gt;

&lt;p&gt;Il s'agit de:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Un framework basé sur des composants pour créer des applications Web évolutives, &lt;/li&gt;
&lt;li&gt;Une collection de bibliothèques bien intégrées qui couvrent une grande variété de fonctionnalités, notamment le routage, la gestion des formulaires, la communication client-serveur, etc.&lt;/li&gt;
&lt;li&gt;Une suite d'outils de développement pour vous aider à développer, créer, tester et mettre à jour votre code&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;En fait, Une application Angular est une interaction entre les artefacts Angular suivants:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Modules&lt;/li&gt;
&lt;li&gt;Services&lt;/li&gt;
&lt;li&gt;Components&lt;/li&gt;
&lt;li&gt;Directives&lt;/li&gt;
&lt;li&gt;Pipes&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Chaque artefact est représenté par une classe Typescript, Angular peut reconnaître une classe Typescript en tant que Angular artifact à l’aide des décorateurs.&lt;/p&gt;

&lt;p&gt;Un décorateur permet principalement de déclarer des métadonnées pour une classe, une méthode, une propriété ou un paramètre. Lors de la configuration d’un component, on déclare des méta-donnés pour cette classe afin d’informer Angular qu’il s’agit d’un component.&lt;/p&gt;

&lt;p&gt;Il existe 4 types de décorateurs en Angular:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Class Decorators&lt;/li&gt;
&lt;li&gt;Property Decorators&lt;/li&gt;
&lt;li&gt;Method Decorators&lt;/li&gt;
&lt;li&gt;Parameter Decorators&lt;/li&gt;
&lt;/ul&gt;
&lt;h4&gt;
  
  
  Décorateurs de class:
&lt;/h4&gt;

&lt;p&gt;Les décorateurs de classe sont les top-levels décorateurs qui sont utilisés pour définir le but des classes. Ils fournissent à Angular des informations indiquant qu'une classe particulière est un component, un module, un service, une pipe ou une directive.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Ex&lt;/em&gt;: &lt;code&gt;@Component&lt;/code&gt;, &lt;code&gt;@NgModule&lt;/code&gt;, &lt;code&gt;@Injectable&lt;/code&gt;, &lt;code&gt;@Pipe&lt;/code&gt;, &lt;code&gt;@Directive&lt;/code&gt;.&lt;/p&gt;
&lt;h4&gt;
  
  
  Décorateur de propriété:
&lt;/h4&gt;

&lt;p&gt;Les décorateurs de propriétés sont utilisés pour décorer les propriétés spécifiques au sein des classes.&lt;br&gt;
Avec les décorateurs, vous pouvez par exemple placer le décorateur @Input() au-dessus de la propriété, pour lequel le compilateur d'Angular créera automatiquement une liaison d'entrée à partir du nom de la propriété et les liera ( Input Binding ).&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Ex:&lt;/em&gt; &lt;code&gt;@Input&lt;/code&gt;, &lt;code&gt;@Output&lt;/code&gt;, &lt;code&gt;@ViewChild&lt;/code&gt;, &lt;em&gt;etc.&lt;/em&gt;&lt;/p&gt;
&lt;h4&gt;
  
  
  Décorateur de méthode:
&lt;/h4&gt;

&lt;p&gt;Un décorateur de méthode décore des méthodes spécifiques au sein d’une classe avec des fonctionnalités. Ceci est déclaré juste avant une déclaration de méthode.&lt;br&gt;
&lt;code&gt;@HostListener&lt;/code&gt; en est un bon exemple. Cela indique à Angular que lorsqu'un événement sur l’hôte se produit, la méthode décorée est appelée avec l'événement.&lt;/p&gt;
&lt;h4&gt;
  
  
  Décorateur de paramètre:
&lt;/h4&gt;

&lt;p&gt;Les décorateurs de paramètres sont utilisés pour décorer les paramètres dans le constructeur de classe. Par exemple - &lt;code&gt;@Inject&lt;/code&gt;. Il indique à Angular avec quoi ce paramètre sera initialisé.&lt;/p&gt;
&lt;h3&gt;
  
  
  Encapsulation de la vue:
&lt;/h3&gt;
&lt;h4&gt;
  
  
  Shadow DOM:
&lt;/h4&gt;

&lt;p&gt;Le Shadow DOM apporte l'encapsulation aux éléments HTML. En utilisant le &lt;strong&gt;shadow DOM&lt;/strong&gt;, les balises, les styles et les comportements sont limités à l'élément et n'entrent pas en conflit avec les autres nœuds du &lt;strong&gt;DOM&lt;/strong&gt;, ç-à-d que si une classe “.test” est définie dans le style du composant A, l'élément du composant B ayant la classe “test” ne sera pas infecté par le style définie dans le composant A. &lt;/p&gt;

&lt;p&gt;Angular n’utilise pas à proprement parlé de &lt;strong&gt;Shadow DOM&lt;/strong&gt;, mais il émule la séparation permise par le &lt;strong&gt;Shadow DOM&lt;/strong&gt; en ajoutant des attributs spécifiques aux éléments&lt;br&gt;
En effet, par défaut, Angular utilise l’émulation du &lt;strong&gt;Shadow DOM&lt;/strong&gt;, et dans les métadonnées des composants (dans &lt;code&gt;@Component&lt;/code&gt;), une propriété est ajoutée par défaut : encapsulation: &lt;code&gt;ViewEncapsulation.Emulated&lt;/code&gt;. Du coup, Angular sera capable de limiter le scope des propriétés CSS à ce composant uniquement pour éviter tout débordement de style à d’autre partie de l’application. Et tout cela, sans utiliser le &lt;strong&gt;Shadow DOM&lt;/strong&gt; &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Mais comment cette émulation ?&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Prenons l’exemple suivant:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;@Component({
  selector: 'app-example',
  templateUrl: 'example.component.html',
  encapsulation: ViewEncapsulation.Emulated
})
class ExampleComponent {}
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Angular va prévoir la génération du template avec cette contrainte. Une fois le HTML compilé, on voit que des attributs se sont rajoutés sur l’élément de notre composant ainsi que sur tous les éléments fils.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;&amp;lt;app-example _ngcontent-0 _nghost-1&amp;gt;
  &amp;lt;div class="example" _ngcontent-1&amp;gt;
    ...

  &amp;lt;/div&amp;gt;
&amp;lt;/app-example&amp;gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Donc, Angular va prendre en considération ces attributs ( uniques pour chaque composants ) lors de génération du CSS final qui va donc pouvoir être complètement isolé à notre composant.&lt;/p&gt;

&lt;p&gt;Si vous souhaitez enlever cette émulation, il suffit d’ajouter la propriété encapsulation: &lt;code&gt;ViewEncapsulation.None&lt;/code&gt; dans les métadonnées du composant.&lt;/p&gt;

&lt;p&gt;Dans le cas d’une &lt;code&gt;ViewEncapsulation.None&lt;/code&gt;, aucune règle CSS ne sera scopée au composant. Dans ce cas, il est possible que le CSS d’autres composants écrase les règles définies dans celui-ci.&lt;/p&gt;

&lt;p&gt;Si vous souhaitez utiliser le &lt;strong&gt;Shadow DOM&lt;/strong&gt;, vous pouvez utiliser &lt;code&gt;ViewEncapsulation.ShadowDom&lt;/code&gt;.&lt;/p&gt;

&lt;h4&gt;
  
  
  Data-Binding:
&lt;/h4&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;La liaison de données ou data binding, est la déclaration d’une relation entre un élément HTML et une source de données ( dans le fichier TypeScript ). Suite à cette déclaration, Angular effectuera les connexions nécessaires.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;La liaison de données permet de ne pas avoir à coder soit-même le rendu initial, la connexion des event listeners, la suppression des valeurs modifiées de l'écran et la mise à jour des valeurs des données de l'application.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Le data binding est le cœur de la réactivité dans une application Angular.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;Les data bindings possibles dans Angular sont les suivants :&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;L’interpolation&lt;/li&gt;
&lt;li&gt;La liaison de propriété (property binding)&lt;/li&gt;
&lt;li&gt;La liaison d’événement (event binding)&lt;/li&gt;
&lt;li&gt;La liaison d’attribut (attribute binding)&lt;/li&gt;
&lt;li&gt;La liaison de classe (class binding)&lt;/li&gt;
&lt;li&gt;La liaison de style (style binding)&lt;/li&gt;
&lt;li&gt;La liaison de données dans les deux sens (two-way data binding)&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Directives:
&lt;/h3&gt;

&lt;p&gt;Dans Angular il existe trois types de directives : les composants, les directives d’attribut et les directives structurelles.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Les directives d’attribut&lt;/strong&gt; modifient le comportement ou l’apparence d’un élément.&lt;br&gt;
Les directives natives de ce type sont &lt;code&gt;ngStyle&lt;/code&gt; et &lt;code&gt;ngClass&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;&lt;code&gt;ngClass&lt;/code&gt; permet d’ajouter/enlever dynamiquement des classes aux éléments HTML du template. &lt;br&gt;
&lt;code&gt;ngStyle&lt;/code&gt; permet d’ajouter/enlever dynamiquement des styles aux éléments HTML du template.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Les directives structurelles&lt;/strong&gt; modifient la structure du DOM, par exemple en ajoutant, supprimant ou manipulant des éléments.&lt;br&gt;
Des exemples de directives natives de ce type sont &lt;code&gt;ngFor&lt;/code&gt;, &lt;code&gt;ngIf&lt;/code&gt; et &lt;code&gt;ngSwitch&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Les directives structurelles&lt;/strong&gt; sont facilement reconnaissables car elles commencent par un astérisque &lt;code&gt;*&lt;/code&gt; qui est en fait un raccourci syntaxique pour &lt;code&gt;&amp;lt;ng-template&amp;gt;&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;Je vous recommande cet &lt;strong&gt;&lt;a href="https://www.freecodecamp.org/news/everything-you-need-to-know-about-ng-template-ng-content-ng-container-and-ngtemplateoutlet-4b7b51223691/"&gt;article&lt;/a&gt;&lt;/strong&gt; génial afin de comprendre parfaitement le &lt;code&gt;&amp;lt;ng-template&amp;gt;&lt;/code&gt; et les autres directives tels que &lt;code&gt;&amp;lt;ng-content&amp;gt;&lt;/code&gt; et &lt;code&gt;&amp;lt;ng-container&amp;gt;&lt;/code&gt;.&lt;/p&gt;
&lt;h3&gt;
  
  
  Services:
&lt;/h3&gt;

&lt;p&gt;Afin d’utiliser les services dans une application Angular, il faut avoir une idée sur &lt;strong&gt;l’injection des dépendances ( Dependency injection )&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;C’est quoi l’injection des dépendances ?&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;L'injection de dépendances&lt;/strong&gt; est une technique par laquelle un objet fournit les dépendances d'un autre objet.&lt;br&gt;
La documentation de Angular décrit &lt;strong&gt;l’injection des dépendances&lt;/strong&gt; comme suit: &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Les dépendances sont des services ou des objets dont une classe a besoin pour remplir sa fonction. L'injection de dépendances, ou DI, est un modèle de conception dans lequel une classe demande des dépendances à des sources externes plutôt que de les créer.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Et elle rajoute encore: &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Le framework DI d'Angular fournit des dépendances à une classe lors de l'instanciation. Utilisez Angular DI pour augmenter la flexibilité et la modularité de vos applications.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Et on pourra aussi bénéficier de l’explication de l’injection des dépendances fourni par &lt;a href="https://www.freecodecamp.org/news/angular-dependency-injection/"&gt;un très bon article sur FreeCodeCamp&lt;/a&gt; où ils disent: &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;L'injection de dépendance est souvent plus simplement appelée DI. Le paradigme existe dans tout Angular. Il maintient le code flexible, testable et modifiable. Les classes peuvent hériter d'une logique externe sans savoir comment la créer. Les consommateurs de ces classes n'ont pas besoin de savoir quoi que ce soit.&lt;/p&gt;

&lt;p&gt;Les services sont un bienfaiteur clé de l'ID. Ils s'appuient sur le paradigme pour l'injection dans divers consommateurs. Ces consommateurs peuvent alors profiter de ce service fourni et/ou le transférer ailleurs. “&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Donc pour résumer, &lt;strong&gt;l’injection des dépendances&lt;/strong&gt; est le paradigme que Angular l’utilise afin qu'une classe puisse utiliser des fonctions et des variables d’une autre classe sans avoir l’instancier, et ces fonctions et variables sont partagées par toutes les autres classes qui en auront besoin.&lt;/p&gt;

&lt;p&gt;Les services qui sont des classes &lt;strong&gt;Singleton&lt;/strong&gt; vont souvent inclure des fonctions et des variables partageables entre plusieurs composants. Chaque composant peut injecter le service dans son constructeur afin de profiter des ses fonctions et de ses variables.&lt;br&gt;
&lt;strong&gt;Mais attends ! c’est quoi le Singleton ?&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Singleton&lt;/strong&gt; est un design pattern qui implique une seule classe qui est chargée de créer une instance tout en s'assurant qu'&lt;strong&gt;une seule instance&lt;/strong&gt; est créée. Cette classe fournit un moyen d'accéder à sa seule instance auquel on peut accéder directement sans avoir besoin d'instancier une autre fois l'objet de la classe. Une classe &lt;strong&gt;Singleton&lt;/strong&gt; donc est une classe qui ne peut être instanciée qu’&lt;strong&gt;une seule fois&lt;/strong&gt; et toutes les autres classes utilisent la même instance lors de leurs communications.&lt;/p&gt;

&lt;p&gt;Dans Angular, un &lt;strong&gt;service&lt;/strong&gt; est une classe &lt;strong&gt;Singleton&lt;/strong&gt; qui ne peut être instancié qu’une seule fois où on peut définir des variables et des fonctions que les composants vont l’utiliser en utilisant &lt;strong&gt;l’injection des dépendances&lt;/strong&gt;, ç-à-d qu’un composant peut injecter la classe du service dans son constructeur pour avoir un accès à ses fonctions et ses variables.&lt;br&gt;
De cette manière la communication entre les composants se déroule.&lt;/p&gt;


&lt;h1&gt;
  
  
  React:
&lt;/h1&gt;

&lt;p&gt;Passons maintenant à la section suivante où on va parler de React.js.&lt;/p&gt;

&lt;p&gt;Comme on a parlé toute à l’heure à propos du DOM, on a mentionné que le navigateur nous donne l'API DOM à laquelle on pouvait accéder en utilisant quelque chose comme innerHTML ou getElementById, cette API nous permet de traverser l'accès DOM à n'importe quel nœud que nous voulons, de les supprimer, d'ajouter un nouveau nœud,  etc. Ce mode de programmation s'appelait Impératif (paradigme impératif) : vous modifiez directement des parties individuelles de votre application en réponse aux événements de l'utilisateur. &lt;/p&gt;

&lt;p&gt;La manipulation du DOM est l'une des tâches de performance les plus importantes, il faut beaucoup de temps pour que les changements DOM se produisent.&lt;/p&gt;

&lt;p&gt;React vous dit: veuillez juste déclarez-moi simplement à quoi ressemble votre application.&lt;/p&gt;

&lt;p&gt;Lorsque un élément JSX est rendu ( rendered ), chaque objet du Virtual DOM est mis à jour. Cela semble incroyablement inefficace, mais le coût est insignifiant car le DOM virtuel peut se mettre à jour si rapidement.&lt;/p&gt;

&lt;p&gt;Une fois le Virtual DOM mis à jour, React compare le nouveau Virtual DOM avec une copie de l’ancien Virtual DOM ( qui a été pris juste avant la mise à jour ).&lt;br&gt;
En comparant le nouveau Virtual DOM avec une version de pré-mise à jour, React détermine exactement quels objets ont été changés. Ce processus est appelé « Diffing ».&lt;/p&gt;

&lt;p&gt;Une fois que React connaît quels objets du Virtual DOM ont été changés, React met alors à jour ces objets, et uniquement ces objets, sur le DOM réel.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Flux de données unidirectionnel:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--S9Z4W6bm--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/gnnl2ry3mp48f9a82ode.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--S9Z4W6bm--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/gnnl2ry3mp48f9a82ode.jpg" alt="Image description" width="709" height="450"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Si l'état a changé dans le composant B, tous les changements ne peuvent que se répercuter, &lt;strong&gt;les données ne peuvent jamais remonter&lt;/strong&gt;. C-a-d que tous les enfants du composants B ainsi que leurs enfants vont être re-rendu.&lt;/p&gt;
&lt;h3&gt;
  
  
  Hooks:
&lt;/h3&gt;
&lt;h4&gt;
  
  
  UseState:
&lt;/h4&gt;

&lt;p&gt;L’état d’un composant React est susceptible d’être changé à un moment donné, lors d’une interaction de l’utilisateur, récupérer des données via une API, etc. Pour que ce changement soit prise en compte au niveau DOM, le hook useState fourni par React est l’élément clé qui nous permet de changer l’état du composant et de notifier le DOM afin de le prendre en considération et l’affiche car le DOM sera re-rendu à chaque changement d’état.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const [nom, setNom] = useState("Sadok");
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;On a défini un champ nommé &lt;strong&gt;“nom”&lt;/strong&gt; dans l’état de notre composant initialisé avec “Sadok”. &lt;br&gt;
Le second paramètre &lt;strong&gt;setNom&lt;/strong&gt; est une fonction permettant de mettre à jour la valeur de ce champ et notifier le DOM qu’un changement au niveau de l’état du composant a eu lieu. &lt;/p&gt;

&lt;p&gt;Note: Généralement, les Hooks de React sont utilisés avec une fonctionnalité de &lt;strong&gt;JavaScript ES6&lt;/strong&gt; connue avec le nom &lt;strong&gt;"Destructuring"&lt;/strong&gt;.&lt;br&gt;
Pour en savoir plus, veuillez trouver une explication de la décomposition en JavaScript dans &lt;a href="https://developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Operators/Spread_syntax"&gt;MDN&lt;/a&gt;.&lt;/p&gt;
&lt;h4&gt;
  
  
  UseEffect:
&lt;/h4&gt;

&lt;p&gt;Le hook &lt;strong&gt;useEffect&lt;/strong&gt; nous permet d'exécuter du code lors d’un changement d’état. Il s’agit d’une fonction qui prend deux paramètres, le premier est la fonction qui va être exécutée après le changement de l’état, le deuxième paramètre est un tableau où on définit les champs en question.&lt;/p&gt;

&lt;p&gt;Prenons l’exemple suivant:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const [eligible, setEligible] = useState(false);
const [age, setAge] = useState("");

useEffect( () =&amp;gt; {
    if ( age &amp;lt;= 35 ) {
        setEligible(true);
}
else {
    setEligible(false);
}
}, [age] );
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;On a définit deux champs dans notre état, age et eligible, supposons qu’on a une application qui fait un controle sur l’age, l’utilisateur saisit son age et s’il est inférieur ou égal à 35 ans alors il est éligible de faire quelque chose, sinon il est non éligible.&lt;/p&gt;

&lt;p&gt;le hook &lt;strong&gt;useEffect&lt;/strong&gt; nous permet de faire ce contrôle là en passant en premier paramètre la fonction permettant de tester si l'âge introduit est inférieur ou égal à 35 ou non et elle mettre à jour le champs eligible en appelant la fonction setEligible, et en second paramètre un tableau contenant le champs à contrôler ( age ). C-a-d qu'après chaque changement de la valeur du champ d’état age, la fonction passé en premier paramètre sera invoquée.&lt;/p&gt;

&lt;p&gt;On peut définir plusieurs champs dans le tableau de dépendance ( le second paramètre de useEffect ).&lt;/p&gt;

&lt;p&gt;On peut définir plusieurs &lt;strong&gt;useEffect&lt;/strong&gt; dans un composant React.&lt;/p&gt;

&lt;p&gt;Tous les &lt;strong&gt;useEffect&lt;/strong&gt; seront exécutés une première fois lors de l’initialisation du composant.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;useEffect&lt;/strong&gt; est le bon endroit pour récupérer les données en passant un tableau vide en deuxième paramètre car de cette façon elle sera invoquée qu’une seule fois après l’initialisation du composant.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;useEffect( () =&amp;gt; {
    getActualites();
    getUsers();
    …
}, [] );
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;strong&gt;useEffect&lt;/strong&gt; peut renvoyer une fonction, qui est appelée une fonction de nettoyage ( clean up function ) qui est invoquée lorsque ce composant va être détruit .&lt;/p&gt;

&lt;h3&gt;
  
  
  Redux et la gestion d'état ( state management ):
&lt;/h3&gt;

&lt;p&gt;Chaque application interactive implique des événements interactifs. &lt;/p&gt;

&lt;p&gt;Dans le contexte de &lt;strong&gt;React.js&lt;/strong&gt; et les &lt;strong&gt;Single Page Applications (SPA)&lt;/strong&gt;, la gestion d'état ( state management ) est un moyen de partager les données entre les différents composants.&lt;br&gt;
En d'autres termes, un état ( state ) est simplement un objet JavaScript représentant une partie d'un composant qui peut changer en fonction des actions de l'utilisateur.&lt;br&gt;
Pour en savoir plus, vous pouvez jeter un coup d'œil sur la &lt;a href="https://reactjs.org/docs/state-and-lifecycle.html"&gt;documentation de React&lt;/a&gt;. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://redux.js.org/"&gt;Redux&lt;/a&gt; est une libraire basée sur l’architecture &lt;strong&gt;Flux&lt;/strong&gt; qui a pour but de faciliter la gestion d’état dans une application React.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Redux&lt;/strong&gt; repose principalement sur 4 acteurs principaux: &lt;strong&gt;Store&lt;/strong&gt;, &lt;strong&gt;Reducer&lt;/strong&gt;, &lt;strong&gt;Actions&lt;/strong&gt;, &lt;strong&gt;Selectors&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Le &lt;strong&gt;Store&lt;/strong&gt; est un conteneur d'état en mémoire. Il ne stocke l'état de notre application que pendant l'exécution de l'application. Il s’agit d’un objet JavaScript englobant.&lt;/p&gt;

&lt;p&gt;En utilisant ce modèle, notre état est immuable, ce qui signifie qu'il n'est jamais modifié à la place, le &lt;strong&gt;Reducer&lt;/strong&gt; crée un nouvel état à partir de l'état existant et &lt;strong&gt;l'Action&lt;/strong&gt; définie qui fournit qu’est ce que va être changé d’un état à un autre à travers un Payload.&lt;/p&gt;

&lt;p&gt;Pour chaque élément du Store, on peut lui associer un &lt;strong&gt;Selector&lt;/strong&gt; qui permet à un composant de s'abonner à cet élément du Store pour être informé de ses changements.&lt;/p&gt;

&lt;p&gt;Lorsqu'un nouvel état est remplacé dans le Store, le composant est informé de ce nouvel état et les valeurs liées dans la vue sont mises à jour.&lt;/p&gt;

&lt;p&gt;Donc, le &lt;strong&gt;Store&lt;/strong&gt; centralise l’état ( state ) de l’application et tous les composants peuvent soit lire les champs qu’ils en auront besoin à travers les &lt;strong&gt;Selectors&lt;/strong&gt;, soit dispatcher des &lt;strong&gt;Actions&lt;/strong&gt; afin de demander au &lt;strong&gt;Reducer&lt;/strong&gt; de faire un changement dans le Store en passant le type de l’action et un Payload contenant les nouvelles données du champs en question.&lt;/p&gt;




&lt;p&gt;Merci pour votre lecture, j’attends vos remarques et feedback dans les commentaires et à la prochaine :D&lt;/p&gt;

</description>
      <category>javascript</category>
      <category>webdev</category>
      <category>angular</category>
      <category>react</category>
    </item>
  </channel>
</rss>
