BabelJS - Travailler avec Babel et JSX

Dans ce chapitre, nous apprendrons à travailler avec JSX et babel. Avant d'entrer dans les détails, voyons ce qu'est JSX.

Qu'est-ce que JSX?

JSX est un code JavaScript contenant une combinaison de syntaxe xml. La balise JSX a un nom de balise, des attributs et des enfants qui la font ressembler à xml.

React utilise JSX pour la création de modèles au lieu de JavaScript standard. Il n'est pas nécessaire de l'utiliser, cependant, voici quelques avantages qui l'accompagnent.

  • Il est plus rapide car il effectue une optimisation lors de la compilation du code en JavaScript.

  • Il est également de type sécurisé et la plupart des erreurs peuvent être détectées lors de la compilation.

  • Il est plus facile et plus rapide d'écrire des modèles, si vous êtes familier avec HTML.

Nous avons utilisé babel 6 dans la configuration du projet. Si vous souhaitez passer à babel 7, installez les packages requis de babel en utilisant@babel/babel-package-name.

Nous allons créer la configuration du projet et utiliser webpack pour compiler jsx avec réagir au JavaScript normal en utilisant Babel.

Pour démarrer la configuration du projet, exécutez les commandes ci-dessous pour l'installation de babel, react et webpack.

commander

npm init

Maintenant, nous allons installer les packages nécessaires avec lesquels nous avons besoin de travailler - babel, webpack et jsx -

npm install --save-dev webpack
npm install --save-dev webpack-cli
npm install --save-dev webpack-dev-server
npm install --save-dev babel-core
npm install --save-dev babel-loader
npm install --save-dev babel-preset-es2015
npm install --save-dev babel-preset-react
npm install --save-dev react
npm install --save-dev react-dom

Voici le package.json après l'installation -

Nous allons maintenant créer un fichier webpack.config.js, qui aura tous les détails pour regrouper les fichiers js et le compiler dans es5 en utilisant babel.

Pour exécuter webpack en utilisant le serveur, il existe quelque chose appelé webpack-server. Nous avons ajouté une commande appelée publier; cette commande démarrera le serveur webpack-dev-server et mettra à jour le chemin où les fichiers finaux sont stockés. Pour le moment, le chemin que nous allons utiliser pour mettre à jour les fichiers finaux est le dossier / dev.

Pour utiliser webpack, nous devons exécuter la commande suivante -

npm run publish

Nous allons créer le webpack.config.js fichiers, qui ont les détails de configuration pour que webpack fonctionne.

Les détails dans le fichier sont les suivants -

var path = require('path');

module.exports = {
   entry: {
      app: './src/main.js'
   },
   output: {
      path: path.resolve(__dirname, 'dev'),
      filename: 'main_bundle.js'
   },
   mode:'development',
   module: {
      rules: [
         {
            test:/\.(js|jsx)$/,
            include: path.resolve(__dirname, 'src'),
            loader: 'babel-loader',
            query: {
               presets: ['es2015','react']
            }
         }
      ]
   }
};

La structure du fichier est comme indiqué ci-dessus. Il commence par le chemin, qui donne les détails du chemin actuel.

var path = require('path'); //gives the current path

Vient ensuite l'objet module.exports, qui a des propriétés entrée, sortie et module.

L'entrée est le point de départ. Ici, nous devons donner les principaux fichiers js que nous voulons compiler.

entry: {
   app: './src/main.js'
},

path.resolve(_dirname, ‘src/main.js’) - cherchera le dossier src dans le répertoire et main.js dans ce dossier.

Production

output: {
   path: path.resolve(__dirname, 'dev'),
   filename: 'main_bundle.js'
},

La sortie est un objet avec des détails de chemin et de nom de fichier. Le chemin contiendra le dossier dans lequel le fichier compilé sera conservé et le nom du fichier indiquera le nom du fichier final à utiliser dans votre.html fichier.

module

module: {
   rules: [
      {
         test:/\.(js|jsx)$/,
         include: path.resolve(__dirname, 'src'),
         loader: 'babel-loader',
         query: {
            presets: ['es2015','react']
         }
      }
   ]
}
  • Le module est un objet avec des détails de règles qui a des propriétés ie test, include, loader, query.

  • Test contiendra les détails de tous les fichiers js se terminant par .js et .jsx.Il a le modèle qui recherchera .js et .jsx à la fin dans le point d'entrée donné.

  • Inclure indique le dossier à utiliser pour rechercher les fichiers.

  • Loader utilise babel-loader pour compiler le code.

  • La requête a des préréglages de propriété, qui est un tableau avec la valeur env - es5 ou es6 ou es7. Nous avons utilisé es2015 et réagissons comme préréglage.

Créer le dossier src/. Ajouter main.js et App.jsx dedans.

App.jsx

import React from 'react';

class App extends React.Component {
   render() {
         var style = {
         color: 'red',
         fontSize: 50
      };
      return (
         <div style={style}>
            Hello World!!!
         </div>
      );
   }
}
export default App;

main.js

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App.jsx';

ReactDOM.render(, document.getElementById('app'));

Exécutez la commande suivante pour regrouper le fichier .js et le convertir à l'aide des préréglages es2015 et react.

commander

npm run pack

Ajouter main_bundle.js du dossier dev vers index.html -

<!DOCTYPE html>
<html lang = "en">
   <head>
      <meta charset = "UTF-8">
      <title>React App</title>
   </head>
   <body>
      <div id = "app"></div>
      <script src = "dev/main_bundle.js"></script>
   </body>
</html>

commander

npm run publish

Production