JSX (JavaScript)

Extension de la syntaxe Javascript utilisée par React.js, Vue et d'autres frameworks similaires pour décrire des éléments HTML comme des littéraux XML dans le code Javascript

JSX (JavaScript Syntax Extension et parfois appelé JavaScript XML) est une extension React de la syntaxe du langage JavaScript [1] qui permet de structurer le rendu des composants à l'aide d'une syntaxe familière à de nombreux développeurs. Il est similaire en apparence au HTML.

Les composants React sont généralement écrits à l'aide de JSX, bien qu'ils ne soient pas obligés de l'être, car les composants peuvent également être écrits en JavaScript pur. JSX est similaire à une autre syntaxe d'extension créée par Facebook pour PHP appelée XHP.

Balisage

Un exemple de code JSX :

const App = () => {  return (   <div>    <p>En-tête</p>    <p>Contenu</p>    <p>Pied de page</p>   </div>  ); }

Éléments imbriqués

Plusieurs éléments du même niveau doivent être enveloppés dans un seul élément React tel que l'élément <div> illustré ci-dessus, un fragment délimité par <Fragment> ou sous sa forme abrégée <>, ou renvoyés sous forme de tableau[2],[3]

Les attributs

JSX fournit une gamme d'attributs d'élément conçus pour refléter ceux fournis par HTML.Des attributs personnalisés peuvent également être transmis au composant[4]. Tous les attributs seront reçus par le composant en tant que propriétés.

Quelques attributs particuliers des composants React :

  • className est une propriété définissant la classe CSS, correspondant à l'attribut HTML class mais renommé en className car class est un mot réservé en Javascript.
  • style est une propriété définissant des règles de style CSS, comme en HTML mais définie obligatoirement sous forme d'un objet au lieu d'une chaîne de caractères. Les noms d'attribut correspondent aux noms des propriétés CSS en remplaçant le tiret par la mise en majuscule de la lettre qui suit. Exemple : style={{ fontWeight:'bold', fontSize:'24pt' }}
  • children est une propriété contenant le tableau des éléments enfants contenus dans le composant.

Expressions JavaScript

Les expressions JavaScript (mais pas les instructions) peuvent être utilisées dans JSX avec des accolades {} :

 <h1>{10+1}</h1>

L'exemple ci-dessus affichera :

 <h1>11</h1>

Expressions conditionnelles

Les instructions If–else ne peuvent pas être utilisées dans JSX, mais des expressions conditionnelles peuvent être utilisées à la place. L'exemple ci-dessous affichera le résultat de l'expression { i === 1 ? 'true' : 'false' } comme la chaîne 'true' car i vaut 1.

const App = () => {  const i = 1;  return (   <div>    <h1>{ i === 1 ? 'true' : 'false' }</h1>   </div>  );}

Ce qui précède affichera :

<div> <h1>true</h1></div>

Les fonctions et JSX peuvent être utilisés au conditionnel :

const App = () => {  const sections = [1, 2, 3];  return (   <div>    {sections.map((n,i) => (      // 'key' est utilisé par react pour pister les items de la liste et leurs changements.      // Chaque valeur 'key' doit être unique.      <div key={"section-" + n}>        Section {n} {i === 0 && (first)}      </div>    ))}   </div>  );}

Ce qui précède affichera :

<div> <div>Section 1(first)</div> <div>Section 2</div> <div>Section 3</div></div>

Le code écrit en JSX nécessite une conversion avec un outil tel que Babel avant de pouvoir être compris par les navigateurs Web[5]. Ce traitement est généralement effectué au cours d'un processus de création de logiciel avant le déploiement de l'application.

Notes et références

Liens externes

🔥 Top keywords: Wikipédia:Accueil principalListe de sondages sur les élections législatives françaises de 2024Spécial:RechercheJordan BardellaChampionnat d'Europe de football 2024N'Golo KantéJodie DevosKylian MbappéÉlections législatives françaises de 2024Marcus ThuramLe Jardin des Finzi-Contini (film)Maria Schneider (actrice)Cookie (informatique)Championnat d'Europe de footballNouveau Front populaireKevin DansoAntoine GriezmannÉric CiottiChampionnat d'Europe de football 2020Dominique SandaMike MaignanWilliam SalibaLionel JospinÉlections législatives de 2024 dans l'EssonneFront populaire (France)Françoise HardyÉlections législatives de 2024 à ParisRassemblement nationalJean-Luc MélenchonFichier:Cleopatra poster.jpgOlivier GiroudSébastien ChenuDidier DeschampsLa Chronique des BridgertonÉlections législatives de 2024 dans les YvelinesLilian ThuramListe de partis politiques en FranceAnne SinclairGabriel Attal