Qu'est-ce que JSX et pourquoi vous devriez l'utiliser pour créer vos applications React

En tant que développeurs, nous utilisons une variété d'outils et de packages open source pour faciliter notre travail. Certains d'entre eux sont si largement utilisés dans la communauté qu'ils semblent natifs de JavaScript. Mais ce n'est pas le cas et ils peuvent fondamentalement changer la façon dont vous écrivez le code au quotidien.

L'une de ces technologies que vous utilisez probablement déjà est JSX - une extension de syntaxe de type XML pour JavaScript . Créé par l'équipe de Facebook, il vise à simplifier l'expérience des développeurs. Comme le dit la spécification, la justification de la création de JSX était:

«… Pour définir une syntaxe concise et familière pour définir des structures arborescentes avec des attributs.» ~ Spécifications JSX

Maintenant, vous vous dites probablement: "Hé, Ryan, ça sonne bien, mais apprends déjà le code ", alors voici notre premier exemple.

const helloWorld = 

Hello, World!

;

Et c'est tout!

L'extrait de code ci-dessus semble familier, mais vous êtes-vous déjà arrêté pour penser à sa puissance? JSX permet de transmettre des arborescences composées d'éléments HTML ou React comme s'il s'agissait de valeurs JavaScript standard.

Bien que vous n'ayez pas besoin d'utiliser JSX lors de l'écriture de React (ou d'utiliser React pour essayer JSX), il est indéniable que c'est une partie importante de l'écosystème React, alors allons-y et voyons ce qui se passe sous le capot.

Premiers pas avec JSX

La première chose à noter lors de l'utilisation de la syntaxe JSX est que React doit être dans la portée. Cela est dû à la façon dont il est compilé. Prenez ce composant par exemple:

function Hello() { return 

Hello, World!

}

Dans les coulisses, chaque élément rendu par le Hellocomposant est transpilé en un React.createElementappel.

Dans ce cas:

function Hello() { return React.createElement("h1", {}, "Hello, World!")}

Il en va de même pour les éléments imbriqués. Les deux exemples ci-dessous rendraient finalement le même balisage.

// Example 1: Using JSX syntaxfunction Nav() { return ( 
  • Home
  • About
  • Portfolio
  • Contact
);}
// Example 2: Not using JSX syntaxfunction Nav() { return ( React.createElement( "ul", {}, React.createElement("li", null, "Home"), React.createElement("li", null, "About"), React.createElement("li", null, "Portfolio"), React.createElement("li", null, "Contact") ) );}

React.createElement

Lorsque React crée des éléments, il appelle cette méthode, qui prend trois arguments.

  1. Le nom de l'élément
  2. Un objet représentant les accessoires de l'élément
  3. Un tableau des enfants de l'élément

Une chose à noter ici est que React interprète les éléments minuscules comme des éléments HTML et Pascal (ex. ThisIsPascalCase) comme des composants personnalisés. Pour cette raison, les exemples suivants seraient interprétés différemment.

// 1. HTML elementReact.createElement("div", null, "Some content text here")
// 2. React elementReact.createElement(Div, null, "Some content text here")

Le premier exemple générerait un iv> with the string "Some content text here" as its child. However, the second version would throw an error (unless, of course, a custom component <Div /> was in scope) because is undefined.

Props in JSX

When working in React, your components often render children and need to pass them data in order for the children to render properly. These are called props.

I like to think of React components as a group of friends. And what do friends do? They give each other props. Thankfully, JSX offers us a number of ways to do that.

// 1. Props defaulted to true
// 2. String literals
// 3. JavaScript expressions
// 4. Spread attributes

But beware! You cannot pass if statements or for loops as props because they are statements, not expressions.

Original text


Children in JSX

As you are building your app, you eventually start having components render children. And then those components sometimes have to render children. And so on and so forth.

Since JSX is meant to make it easy for us to reason about tree-like structures of elements, it makes all of this very easy. Basically, whatever elements a component returns become its children.

There are four ways to render child elements using JSX:

Strings

This is the simplest example of JSX children. In the case below, React creates a <h1> HTML element with one child. The child, however, is not another HTML element, just a simple string.

function AlertBanner() { return ( 

Your bill is due in 2 days

)}

JSX Elements

This is probably the use case that new React developers would be most familiar with. In the component below, we’re returning an HTML child (the er>), which has two children of its own &lt;Nav /> and &lt;ProfilePic /> both of which are custom defined JSX elements.

function Header(props) { return (     )}

Expressions

Expressions allow us to easily render elements in our UI that are the result of a JavaScript computation. A simple example of this would be basic addition.

Say we have a component called /> that renders information about a bill or receipt. Let’s assume it takes one prop called total that represents the pre-tax cost and another prop taxRate, which represents the applicable tax rate.

Using expressions, we can easily render out some useful information for our users!

function BillFooter(props) { return ( 
Tax: {props.total * props.taxRate}
Total: {props.total + props.total * props.taxRate}
);}

Functions

With functions, we can programmatically create elements and structures, which React will then render for us. This makes it easy to create multiple instances of a component or render repeated UI elements.

As an example, let’s use JavaScript’s .map() function to create a navigation bar.

// Array of page informationconst pages = [ { id: 1, text: "Home", link: "/" }, { id: 2, text: "Portfolio", link: "/portfolio" }, { id: 3, text: "Contact", link: "/contact" }];// Renders a 
    with programmatically created
  • childrenfunction Nav() { return (
      {pages.map(page => { return (
    • {page.text}
    • ); })}
    );}

Now, if we want to add a new page to our site, all we need to do is add a new object to the pages array and React will take care of the rest!

Take note of the key prop. Our function returns an array of sibling elements, in this case <li>s, and React needs a way to keep track of which mounts, unmounts or updates. To do that, it relies on this unique identifier for each element.

Use the tools!

Sure, you can write React applications without JSX, but I’m not really sure why you’d want to.

The ability JSX gives us to pass around elements in JavaScript like they were first-class citizen lends itself well to working with the rest of the React ecosystem. So well, in fact, you may have been writing it every day and not even known it.

Bottom line: just use JSX. You’ll be happy you did.