BabelJS - Transpile ES6 fonctionnalités vers ES5

Dans ce chapitre, nous verrons les fonctionnalités ajoutées à ES6. Nous apprendrons également à compiler les fonctionnalités sur ES5 à l'aide de BabelJS.

Voici les différentes fonctionnalités d'ES6 que nous aborderons dans ce chapitre -

  • Soit + Const
  • Fonctions fléchées
  • Classes
  • Promises
  • Generators
  • Destructuring
  • Iterators
  • Template Literalst
  • Objet amélioré
  • Propriétés par défaut, repos et propagation

Soit + Const

Let déclare une variable locale de portée de bloc en JavaScript. Prenons l'exemple suivant pour comprendre l'utilisation de let.

Exemple

let a = 1;
if (a == 1) {
   let a = 2;
   console.log(a);
}
console.log(a);

Production

2
1

La raison pour laquelle la première console imprime 2 est que a est déclaré à nouveau en utilisant let et ne sera disponible que dans le ifbloquer. Toute variable déclarée à l'aide de let est uniquement disponible dans le bloc déclaré. Nous avons déclaré la variable a deux fois en utilisant let, mais elle n'écrase pas la valeur de a.

C'est la différence entre les mots-clés var et let. Lorsque vous déclarez une variable en utilisant var, la variable sera disponible dans la portée de la fonction ou, si elle est déclarée, agira comme une variable globale.

Si une variable est déclarée avec let, la variable est disponible dans la portée du bloc. S'il est déclaré dans l'instruction if, il ne sera disponible que dans le bloc if. Il en va de même pour le commutateur, la boucle for, etc.

Nous allons maintenant voir la conversion de code dans ES5 en utilisant babeljs.

Exécutons la commande suivante pour convertir le code -

npx babel let.js --out-file let_es5.js

La sortie de es6 à es5 pour le mot-clé let est la suivante -

Laisser utiliser ES6

let a = 1;
if (a == 1) {
   let a = 2;
   console.log(a);
}
console.log(a);

Transpilé à l'aide de babel vers ES5

"use strict";

var a = 1;
if (a == 1) {
   var _a = 2;
   console.log(_a);
}
console.log(a);

Si vous voyez le code ES5, le mot clé let est remplacé par le varmot-clé. De plus, la variable à l'intérieur du bloc if est renommée en_a pour avoir le même effet que lorsqu'il est déclaré avec le let mot-clé.

Const

Dans cette section, nous découvrirons le fonctionnement du mot-clé const dans ES6 et ES5. Le mot clé Const est également disponible dans la portée; et si à l'extérieur, il jettera une erreur. La valeur de la variable déclarée const ne peut pas être modifiée une fois affectée. Prenons l'exemple suivant pour comprendre comment le mot clé const est utilisé.

Exemple

let a =1;
if (a == 1) {
   const age = 10;
}
console.log(age);

Production

Uncaught ReferenceError: age is not defined at 
      
       :5:13 
      

La sortie ci-dessus renvoie une erreur car la const age est définie dans le bloc if et est disponible dans le bloc if.

Nous comprendrons la conversion vers ES5 en utilisant BabelJS.

ES6

let a =1;
if (a == 1) {
   const age = 10;
}
console.log(age);

Commander

npx babel const.js --out-file const_es5.js

Transpilé en ES6 avec BabelJS

"use strict";

var a = 1;
if (a == 1) {
   var _age = 10;
}
console.log(age);

Dans le cas de ES5, le mot clé const est remplacé par le mot clé var comme indiqué ci-dessus.

Fonctions fléchées

Une fonction Arrow a une syntaxe plus courte par rapport à l'expression variable. elle est également appelée fonction de flèche grasse ou fonction lambda. La fonction n'a pas sa propre propriété. Dans cette fonction, la fonction mot-clé est omise.

Exemple

var add = (x,y) => {
   return x+y;
}

var k = add(3,6);
console.log(k);

Production

9

En utilisant BabelJS, nous transpilerons le code ci-dessus vers ES5.

ES6 - Fonction flèche

var add = (x,y) => {
   return x+y;
}

var k = add(3,6);
console.log(k);

Commander

npx babel arrowfunction.js --out-file arrowfunction_es5.js

BabelJS - ES5

En utilisant Babel, la fonction de flèche est convertie en fonction d'expression variable comme indiqué ci-dessous.

"use strict";

var add = function add(x, y) {
   return x + y;
};

var k = add(3, 6);
console.log(k);

Des classes

ES6 est livré avec la nouvelle fonctionnalité Classes. Les classes sont similaires à l'héritage basé sur un prototype disponible dans ES5. Le mot clé class est utilisé pour définir la classe. Les classes sont comme des fonctions spéciales et ont des similitudes comme l'expression de fonction. Il a un constructeur, qui est appelé à l'intérieur de la classe.

Exemple

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;
   }
}
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

Production

Siya-Kapoor

ES6 - Classes

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;
   }
}
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

Commander

npx babel class.js --out-file class_es5.js

BabelJS - ES5

Un code supplémentaire a été ajouté à l'aide de babeljs pour que la fonctionnalité fonctionne pour les classes comme dans ES5.BabelJs s'assure que la fonctionnalité fonctionne de la même manière qu'elle l'aurait fait dans ES6.

"use strict";

var _createClass = function () {
   function defineProperties(target, props) {
      for (var i = 0; i < props.length; i++) {
         var descriptor = props[i];
         descriptor.enumerable = descriptor.enumerable || false;
         descriptor.configurable = true;
         if ("value" in descriptor) descriptor.writable = true;
         Object.defineProperty(target, descriptor.key, descriptor);
      }
   }
   return function (Constructor, protoProps, staticProps) {
      if (protoProps) defineProperties(Constructor.prototype, protoProps);
      if (staticProps) defineProperties(Constructor, staticProps);
      return Constructor;
   };
}();

function _classCallCheck(instance, Constructor) {
   if (!(instance instanceof Constructor)) {
      throw new TypeError("Cannot call a class as a function");
   }
}

var Person = function () {
   function Person(fname, lname, age, address) {
      _classCallCheck(this, Person);

      this.fname = fname;
      this.lname = lname;
      this.age = age;
      this.address = address;
   }

   _createClass(Person, [{
      key: "fullname",
      get: function get() {
         return this.fname + "-" + this.lname;
      }
   }]);

   return Person;
}();

var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

Promesses

Les promesses JavaScript sont utilisées pour gérer les requêtes asynchrones dans votre code.

Cela facilite la vie et maintient le code propre lorsque vous gérez plusieurs rappels à partir de demandes asynchrones, qui ont des dépendances. Les promesses offrent une meilleure façon de travailler avec les fonctions de rappel. Les promesses font partie de ES6. Par défaut, lorsque vous créez une promesse, l'état de la promesse est en attente.

Les promesses viennent dans trois états -

  • en attente (état initial)
  • résolu (terminé avec succès)
  • rejected(failed)

new Promise()est utilisé pour construire une promesse. Le constructeur de promesse a un argument, qui est une fonction de rappel. La fonction de rappel a deux arguments: résoudre et rejeter;

ce sont tous deux des fonctions internes. Le code asynchrone que vous écrivez, c'est-à-dire l'appel Ajax, le chargement d'image, les fonctions de minutage ira dans la fonction de rappel.

Si la tâche exécutée dans la fonction de rappel réussit, la fonction de résolution est appelée; sinon, la fonction de rejet est appelée avec les détails de l'erreur.

La ligne de code suivante montre un appel de structure de promesse -

var _promise = new Promise (function(resolve, reject) {
   var success = true;
   if (success) {
      resolve("success");
   } else {
      reject("failure");
   }
});
_promise.then(function(value) {
   //once function resolve gets called it comes over here with the value passed in resolve
   console.log(value); //success
}).catch(function(value) {
   //once function reject gets called it comes over here with the value passed in reject
   console.log(value); // failure.
});

Exemple de promesse ES6

let timingpromise = new Promise((resolve, reject) => {
   setTimeout(function() {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then((msg) => {
   console.log(msg);
});

Production

Promise is resolved!

ES6 - Promesses

let timingpromise = new Promise((resolve, reject) => {
   setTimeout(function() {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then((msg) => {
   console.log(msg);
});

Commander

npx babel promise.js --out-file promise_es5.js

BabelJS - ES5

"use strict";

var timingpromise = new Promise(function (resolve, reject) {
   setTimeout(function () {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then(function (msg) {
   console.log(msg);
});

Pour les promesses, le code ne change pas lorsqu'il est transpilé. Nous devons utiliser babel-polyfill pour qu'il fonctionne sur les anciens navigateurs. Les détails sur babel-polyfills sont expliqués dans le chapitre babel - poyfill.

Générateurs

La fonction du générateur est comme normale function. La fonction a une fonction de syntaxe spéciale * avec * à la fonction et le mot-clé yield à utiliser dans la fonction. Ceci est destiné à mettre en pause ou à démarrer la fonction si nécessaire. Les fonctions normales ne peuvent pas être arrêtées entre le début de l'exécution. Il exécutera la fonction complète ou s'arrêtera lorsqu'il rencontrera l'instruction return. Generator fonctionne différemment ici, vous pouvez arrêter la fonction avec le mot-clé yield et la redémarrer en appelant à nouveau le générateur chaque fois que nécessaire.

Exemple

function* generatorfunction(a) {
   yield a;
   yield a +1 ;
}

let g = generatorfunction(8);
console.log(g.next());
console.log(g.next());

Production

{value: 8, done: false}
{value: 9, done: false}

ES6 - Générateur

function* generatorfunction(a) {
   yield a;
   yield a +1 ;
}

let g = generatorfunction(8);
console.log(g.next());
console.log(g.next());

Commander

npx babel generator.js --out-file generator_es5.js

BabelJS - ES5

"use strict";

var _marked = /*#__PURE__*/regeneratorRuntime.mark(generatorfunction);

function generatorfunction(a) {
   return regeneratorRuntime.wrap(function generatorfunction$(_context) {
      while (1) {
         switch (_context.prev = _context.next) {
            case 0:
               _context.next = 2;
               return a;

            case 2:
               _context.next = 4;
               return a + 1;
               
            case 4:
            case "end":
               return _context.stop();
         }
      }
   }, _marked, this);
}

var g = generatorfunction(8);
console.log(g.next());
console.log(g.next());

Itérateurs

Iterator en JavaScript rend un objet JavaScript, qui a de la valeur. L'objet a également un indicateur appelé done, qui a une valeur vrai / faux. Il donne false si ce n'est pas la fin de l'itérateur. Prenons un exemple et voyons le fonctionnement de l'itérateur sur un tableau.

Exemple

let numbers = [4, 7, 3, 10];
let a = numbers[Symbol.iterator]();
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());

Dans l'exemple ci-dessus, nous avons utilisé un tableau de nombres et appelé une fonction sur le tableau en utilisant Symbol.iterator comme index.

La sortie que nous obtenons en utilisant next () sur le tableau est la suivante -

{value: 4, done: false}
{value: 7, done: false}
{value: 3, done: false}
{value: 10, done: false}
{value: undefined, done: true}

La sortie donne un objet avec une valeur et se fait en tant que propriétés. Chaquenext()L'appel de méthode donne la valeur suivante du tableau et se fait comme faux. La valeur de done ne sera vraie que lorsque les éléments du tableau seront terminés. Nous pouvons l'utiliser pour itérer sur des tableaux. Il y a plus d'options disponibles comme lefor-of boucle qui est utilisée comme suit -

Exemple

let numbers = [4, 7, 3, 10];
for (let n of numbers) {
   console.log(n);
}

Production

4
7
3
10

Quand le for-of looputilise la clé, il donne des détails sur les valeurs du tableau comme indiqué ci-dessus. Nous allons vérifier les deux combinaisons et voir comment babeljs les transpile en es5.

Exemple

let numbers = [4, 7, 3, 10];
let a = numbers[Symbol.iterator]();
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());

let _array = [4, 7, 3, 10];
for (let n of _array) {
   console.log(n);
}

commander

npx babel iterator.js --out-file iterator_es5.js

Production

"use strict";

var numbers = [4, 7, 3, 10];
var a = numbers[Symbol.iterator]();
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());
console.log(a.next());

var _array = [4, 7, 3, 10];
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;

try {
   for (var _iterator = _array[Symbol.iterator](),
      _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done);
      _iteratorNormalCompletion = true) {
      var n = _step.value;

      console.log(n);
   }
} catch (err) {
   _didIteratorError = true;
   _iteratorError = err;
} finally {
   try {
      if (!_iteratorNormalCompletion && _iterator.return) {
         _iterator.return();
      }
   } finally {
      if (_didIteratorError) {
         throw _iteratorError;
      }
   }
}

Il y a des changements ajoutés for-ofboucle dans es5. Mais iterator.next est laissé tel quel. Nous devons utiliserbabel-polyfillpour le faire fonctionner dans les anciens navigateurs. Babel-polyfill est installé avec babel et le même peut être utilisé à partir de node_modules comme indiqué ci-dessous -

Exemple

<html>
   <head>
      <script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>
      <script type="text/javascript" src="iterator_es5.js"></script>
   </head>
   <body>
      <h1>Iterators</h1>
   </body>
</html>

Production

Destructuration

La propriété de destruction se comporte comme une expression JavaScript qui décompresse les valeurs des tableaux, des objets.

L'exemple suivant expliquera le fonctionnement de la syntaxe de déstructuration.

Exemple

let x, y, rem;
[x, y] = [10, 20];

console.log(x);
console.log(y);
[x, y, ...rem] = [10, 20, 30, 40, 50];
console.log(rem);

let z = 0;
({ x, y } = (z) ? { x: 10, y: 20 } : { x: 1, y: 2 });
console.log(x);
console.log(y);

Production

10
20
[30, 40, 50]
1
2

La ligne de code ci-dessus montre comment les valeurs sont affectées du côté droit du tableau aux variables du côté gauche. La variable avec...rem obtient toutes les valeurs restantes du tableau.

Nous pouvons également affecter les valeurs de l'objet sur le côté gauche en utilisant l'opérateur conditionnel comme indiqué ci-dessous -

({ x, y } = (z) ? { x: 10, y: 20 } : { x: 1, y: 2 });
console.log(x); // 1
console.log(y); // 2

Convertissons la même chose en ES5 en utilisant babeljs -

commander

npx babel destructm.js --out-file destruct_es5.js

destruct_es5.js

"use strict";

var x = void 0,
   y = void 0,
   rem = void 0;
x = 10;
y = 20;

console.log(x);
console.log(y);
x = 10;
y = 20;
rem = [30, 40, 50];

console.log(rem);

var z = 0;

var _ref = z ? { x: 10, y: 20 } : { x: 1, y: 2 };

x = _ref.x;
y = _ref.y;

console.log(x);
console.log(y);

Littéraux de modèle

Le littéral de modèle est un littéral de chaîne qui autorise les expressions à l'intérieur. Il utilise un backtick (``) au lieu de guillemets simples ou doubles. Quand nous disons expression dans une chaîne, cela signifie que nous pouvons utiliser des variables, appeler une fonction, etc. à l'intérieur de la chaîne.

Exemple

let a = 5;
let b = 10;
console.log(`Using Template literal : Value is ${a + b}.`);
console.log("Using normal way : Value is " + (a + b));

Production

Using Template literal : Value is 15.
Using normal way : Value is 15

ES6 - Modèle littéral

let a = 5;
let b = 10;
console.log(`Using Template literal : Value is ${a + b}.`);
console.log("Using normal way : Value is " + (a + b));

commander

npx babel templateliteral.js --out-file templateliteral_es5.js

BabelJS - ES5

"use strict";

var a = 5;
var b = 10;
console.log("Using Template literal : Value is " + (a + b) + ".");

console.log("Using normal way : Value is " + (a + b));

Littéraux d'objets améliorés

Dans es6, les nouvelles fonctionnalités ajoutées aux littéraux d'objet sont très bonnes et utiles. Nous allons parcourir quelques exemples d'objet littéral dans ES5 et ES6 -

Exemple

ES5
var red = 1, green = 2, blue = 3;
var rgbes5 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes5); // {red: 1, green: 2, blue: 3}

ES6
let rgbes6 = {
   red,
   green,
   blue
};
console.log(rgbes6); // {red: 1, green: 2, blue: 3}

Si vous voyez le code ci-dessus, l'objet dans ES5 et ES6 diffère. Dans ES6, nous n'avons pas à spécifier la valeur de clé si les noms de variable sont identiques à la clé.

Voyons la compilation vers ES5 en utilisant babel.

Objet littéral ES6 amélioré

const red = 1, green = 2, blue = 3;
let rgbes5 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes5);

let rgbes6 = {
   red,
   green,
   blue
};
console.log(rgbes6);

let brand = "carbrand";
const cars = {
   [brand]: "BMW"
}
console.log(cars.carbrand);  //"BMW"

commander

npx babel enhancedobjliteral.js --out-file enhancedobjliteral_es5.js

BabelJS - ES5

"use strict";

function _defineProperty(obj, key, value) {
   if (key in obj) {
      Object.defineProperty(obj, key, {
         value: value, enumerable: true, configurable: true, writable: true
      });
   } else { obj[key] = value; } return obj;
}

var red = 1,
   green = 2,
   blue = 3;
var rgbes5 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes5);

var rgbes6 = {
   red: red,
   green: green,
   blue: blue
};
console.log(rgbes6);

var brand = "carbrand";
var cars = _defineProperty({}, brand, "BMW");

console.log(cars.carbrand); //"BMW"

Propriétés par défaut, repos et propagation

Dans cette section, nous discuterons des propriétés par défaut, repos et propagation.

Défaut

Avec ES6, nous pouvons utiliser les paramètres par défaut pour les paramètres de fonction comme suit -

Exemple

let add = (a, b = 3) => {
   return a + b;
}

console.log(add(10, 20));  // 30
console.log(add(10));      // 13

Transpilons le code ci-dessus dans ES5 en utilisant babel.

commander

npx babel default.js --out-file default_es5.js

BabelJS - ES5

"use strict";

var add = function add(a) {
   var b = arguments.length > 1 >> arguments[1] !== undefined ? arguments[1] : 3;
   return a + b;
};

console.log(add(10, 20));
console.log(add(10));

Du repos

Le paramètre de repos commence par trois points (...) comme indiqué dans l'exemple ci-dessous -

Exemple

let add = (...args) => {
   let sum = 0;
   args.forEach(function (n) {
      sum += n;
   });
   return sum;
};

console.log(add(1, 2));    // 3
console.log(add(1, 2, 5, 6, 6, 7));   //27

Dans la fonction ci-dessus, nous transmettons n nombre de paramètres à la fonction add. Pour ajouter tous ces paramètres si c'était dans ES5, nous devons nous fier à l'objet arguments pour obtenir les détails des arguments. Avec ES6,rest it aide à définir les arguments avec trois points comme indiqué ci-dessus et nous pouvons faire une boucle et obtenir la somme des nombres.

Note - Nous ne pouvons pas utiliser d'arguments supplémentaires lors de l'utilisation de trois points, c'est-à-dire repos.

Exemple

let add = (...args, value) => {    //syntax error
   let sum = 0;
   args.forEach(function (n) {
      sum += n;
   });
   return sum;
};

Le code ci-dessus donnera une erreur de syntaxe.

La compilation vers es5 se présente comme suit -

commander

npx babel rest.js --out-file rest_es5.js

Babel -ES5

"use strict";

var add = function add() {
   for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
      args[_key] = arguments[_key];
   }

   var sum = 0;
   args.forEach(function (n) {
      sum += n;
   });
   return sum;
};

console.log(add(1, 2));
console.log(add(1, 2, 5, 6, 6, 7));

Propagé

La propriété Spread a également les trois points comme repos. Voici un exemple de travail qui montre comment utiliser la propriété spread.

Exemple

let add = (a, b, c) => {
   return a + b + c;
}
let arr = [11, 23, 3];
console.log(add(...arr));   //37

Voyons maintenant comment le code ci-dessus est transpilé en utilisant babel -

commander

npx babel spread.js --out-file spread_es5.js

Babel-ES5

"use strict";

var add = function add(a, b, c) {
   return a + b + c;
};
var arr = [11, 23, 3];
console.log(add.apply(undefined, arr));

Proxies

Le proxy est un objet dans lequel vous pouvez définir un comportement personnalisé pour des opérations telles que la recherche de propriétés, l'affectation, l'énumération, la fonction, l'appel, etc.

Syntaxe

var a = new Proxy(target, handler);

La cible et le gestionnaire sont des objets.

  • target est un objet ou peut être un autre élément proxy.

  • handler sera un objet avec ses propriétés en tant que fonctions qui donneront le comportement lors de l'appel.

Essayons de comprendre ces fonctionnalités à l'aide d'un exemple -

Exemple

let handler = {
   get: function (target, name) {
      return name in target ? target[name] : "invalid key";
   }
};

let o = {
   name: 'Siya Kapoor',
   addr: 'Mumbai'
}

let a = new Proxy(o, handler);
console.log(a.name);
console.log(a.addr);
console.log(a.age);

Nous avons défini la cible et le gestionnaire dans l'exemple ci-dessus et l'avons utilisé avec proxy. Le proxy renvoie l'objet avec des valeurs-clés.

Production

Siya Kapoor
Mumbai
invalid key

Voyons maintenant comment transpiler le code ci-dessus vers ES5 en utilisant babel -

commander

npx babel proxy.js --out-file proxy_es5.js

Babel-ES5

'use strict';

var handler = {
   get: function get(target, name) {
      return name in target ? target[name] : "invalid key";
   }
};

var o = {
   name: 'Siya Kapoor',
   addr: 'Mumbai'
};

var a = new Proxy(o, handler);
console.log(a.name);
console.log(a.addr);
console.log(a.age);