BabelJS - Travailler avec Babel et Webpack

Webpack est un bundler de modules qui regroupe tous les modules avec des dépendances - js, styles, images, etc. dans des actifs statiques .js, .css, .jpg, .png, etc. Webpack est livré avec des préréglages qui aident à la compilation dans la forme requise. Par exemple, le préréglage de réaction qui aide à obtenir la sortie finale sous forme de réaction, le préréglage es2015 ou env qui aide à compiler le code dans ES5 ou 6 ou 7, etc. Nous avons utilisé babel 6 dans la configuration du projet. Si vous souhaitez passer à babel7, installez les packages requis de babel en utilisant @ babel / babel-package-name.

Ici, nous discuterons de la configuration du projet en utilisant babel et webpack. Créez un dossier appelé et ouvrez-le dans l'IDE de Visual Studio.

Pour créer la configuration du projet, exécutez npm initbabelwebpack comme suit -

Voici le package.json créé après npm init -

Maintenant, nous allons installer les packages nécessaires dont nous avons besoin pour travailler avec babel et webpack.

npm install --save-dev webpack
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-env

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

Maintenant, nous allons créer un fichier webpack.config.js, qui aura tous les détails pour regrouper les fichiers js. Ces fichiers seront compilés dans es5 en utilisant babel.

Pour exécuter webpack en utilisant le serveur, nous utilisons webpack-server. Voici les détails qui y sont ajoutés -

Nous avons ajouté la commande publish qui 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 devons d'abord créer les fichiers webpack.config.js. Ceux-ci auront 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$/,
            include: path.resolve(__dirname, 'src'),
            loader: 'babel-loader',
            query: {
               presets: ['env']
            }
         }
      ]
   }
};

La structure du fichier est comme indiqué ci-dessus. Il commence par le chemin h, 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 qui doivent être compilés.

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 fichier .html.

module

module: {
   rules: [
      {
         test: /\.js$/,
         include: path.resolve(__dirname, 'src'),
         loader: 'babel-loader',
         query: {
            presets: ['env']
         }
      }
   ]
}
  • Le module est un objet avec des détails sur les règles. Il a les propriétés suivantes -

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

  • Inclure indique au dossier utilisé sur les fichiers à examiner.

  • Loader utilise babel-loader pour compiler des codes.

  • La requête a des préréglages de propriété, qui est un tableau avec la valeur env - es5 ou es6 ou es7.

Créez le dossier src et main.js dedans; écrivez votre code js dans ES6. Plus tard, exécutez la commande pour le voir se compiler vers es5 à l'aide de webpack et babel.

src/main.js

let add = (a,b) => {
   return a+b;
};
let c = add(10, 20);
console.log(c);

Exécutez la commande -

npm run pack

Le fichier compilé se présente comme suit -

dev/main_bundle.js

!function(e) {
   var t = {};
   function r(n) {
      if(t[n])return t[n].exports;var o = t[n] = {i:n,l:!1,exports:{}};
      return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports
   }
   r.m = e,r.c = t,r.d = function(e,t,n) {
      r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})
   },
   r.r = function(e) {
      "undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})
   },
   r.t = function(e,t) {
      if(1&t&&(e = r(e)),8&t)return e;
      if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;
      var n = Object.create(null);
      if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)r.d(n,o,function(t) {return e[t]}.bind(null,o));
      return n
   },
   r.n = function(e) {
      var t = e&&e.__esModule?function() {return e.default}:function() {return e};
      return r.d(t,"a",t),t
   },
   r.o = function(e,t) {return Object.prototype.hasOwnProperty.call(e,t)},
   r.p = "",r(r.s = 0)
}([function(e,t,r) {"use strict";var n = function(e,t) {return e+t}(10,20);console.log(n)}]);
!function(e) {
   var t = {};
   function r(n) {
      if(t[n])return t[n].exports;
      var o = t[n] = {i:n,l:!1,exports:{}};
      return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports
   }
   r.m = e,r.c = t,r.d = function(e,t,n) {
      r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})
   },
   r.r = function(e) {
      "undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})
   },
   r.t = function(e,t) {
      if(1&t&&(e=r(e)),
      8&t)return e;
      if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;
      var n = Object.create(null);
      if(
         r.r(n),
         Object.defineProperty(n,"default",{enumerable:!0,value:e}),
         2&t&&"string"!=typeof e
      )
      for(var o in e)r.d(n,o,function(t) {return e[t]}.bind(null,o));
      return n
   },
   r.n = function(e) {
      var t = e&&e.__esModule?function() {return e.default}:function() {return e};
      return r.d(t,"a",t),t
   },
   r.o = function(e,t) {
      return Object.prototype.hasOwnProperty.call(e,t)
   },
   r.p = "",r(r.s = 0)
}([function(e,t,r) {
   "use strict";
   var n = function(e,t) {return e+t}(10,20);
   console.log(n)
}]);

Le code est compilé comme indiqué ci-dessus. Webpack ajoute du code requis en interne et le code de main.js apparaît à la fin. Nous avons consolé la valeur comme indiqué ci-dessus.

Ajoutez le fichier js final dans le fichier .html comme suit -

<html>
   <head></head>
   <body>
      <script type="text/javascript" src="dev/main_bundle.js"></script>
   </body>
</html>

Exécutez la commande -

npm run publish

Pour vérifier la sortie, nous pouvons ouvrir le fichier dans -

http://localhost:8080/

Nous obtenons la valeur de la console comme indiqué ci-dessus. Essayons maintenant de compiler en un seul fichier en utilisant webpack et babel.

Nous utiliserons webpack pour regrouper plusieurs fichiers js dans un seul fichier. Babel sera utilisé pour compiler le code es6 vers es5.

Maintenant, nous avons 2 fichiers js dans le dossier src / - main.js et Person.js comme suit -

person.js

export class Person {
   constructor(fname, lname, age, address) {
      this.fname = fname;
      this.lname = lname;
      this.age = age;
      this.address = address;
   }

   get fullname() {
      return this.fname +"-"+this.lname;
   }
}

Nous avons utilisé l'exportation pour utiliser les détails de la classe Person.

main.js

import {Person} from './person'
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;
console.log(persondet);

Dans main.js, nous avons importé Person à partir du chemin du fichier.

Note- Nous n'avons pas besoin d'inclure person.js mais juste le nom du fichier. Nous avons créé un objet de la classe Person et consolidé les détails comme indiqué ci-dessus.

Webpack combinera person.js et main.js et mettre à jour dans dev/main_bundle.jscomme un seul fichier. Exécutez la commandenpm run publish pour vérifier la sortie dans le navigateur -