BabelJS - Transpile ES7 funkcje do ES5

W tym rozdziale dowiemy się, jak przenieść funkcje ES7 do ES5.

ECMA Script 7 ma następujące nowe funkcje dodane do niego -

  • Async-Await
  • Operator potęgowania
  • Array.prototype.includes()

Skompilujemy je do ES5 przy użyciu babeljs. W zależności od wymagań projektu możliwe jest również skompilowanie kodu w dowolnej wersji ecma tj. ES7 do ES6 lub ES7 do ES5. Ponieważ wersja ES5 jest najbardziej stabilna i działa dobrze na wszystkich nowoczesnych i starych przeglądarkach, skompilujemy kod do ES5.

Async-Await

Async to funkcja asynchroniczna, która zwraca niejawną obietnicę. Obietnica zostaje rozwiązana lub odrzucona. Funkcja asynchroniczna jest taka sama jak normalna funkcja standardowa. Funkcja może mieć wyrażenie await, które wstrzymuje wykonywanie do momentu zwrócenia obietnicy, a gdy ją otrzyma, wykonywanie jest kontynuowane. Oczekiwanie będzie działać tylko wtedy, gdy funkcja jest asynchroniczna.

Oto działający przykład dotyczący asynchronizacji i oczekiwania.

Przykład

let timer = () => {
   return new Promise(resolve => {
      setTimeout(() => {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
let out = async () => {
   let msg = await timer();
   console.log(msg);
   console.log("hello after await");
};
out();

Wynik

Promise resolved after 5 seconds
hello after await

Wyrażenie await jest dodawane przed wywołaniem funkcji timera. Funkcja timera zwróci obietnicę po 5 sekundach. Więc czekaj zatrzyma wykonanie, aż obietnica funkcji timera zostanie rozwiązana lub odrzucona, a później będzie kontynuowana.

Prześlijmy teraz powyższy kod do ES5 za pomocą babel.

ES7 - Async-Await

let timer = () => {
   return new Promise(resolve => {
      setTimeout(() => {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
let out = async () => {
   let msg = await timer();
   console.log(msg);
   console.log("hello after await");
};
out();

Komenda

npx babel asyncawait.js --out-file asyncawait_es5.js

BabelJS - ES5

"use strict";

var timer = function timer() {
   return new Promise(function (resolve) {
      setTimeout(function () {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
var out = async function out() {
   var msg = await timer();
   console.log(msg);
   console.log("hello after await");
};

out();

Babeljs nie kompiluje obiektów ani metod; więc tutaj użyte obietnice nie zostaną transponowane i zostaną pokazane tak, jak są. Aby obsługiwać obietnice w starych przeglądarkach, musimy dodać kod, który będzie obsługiwał obietnice. Na razie zainstalujmy babel-polyfill w następujący sposób -

npm install --save babel-polyfill

Powinien być zapisany jako zależność, a nie zależność od dev.

Aby uruchomić kod w przeglądarce, użyjemy pliku polyfill z node_modules \ babel-polyfill \ dist \ polyfill.min.js i wywołamy go za pomocą tagu script, jak pokazano poniżej -

<!DOCTYPE html>
<html>
   <head>
      <title>BabelJs Testing</title>
   </head>
   <body>
      <script src="node_modules\babel-polyfill\dist\polyfill.min.js" type="text/javascript"></script>
      <script type="text/javascript" src="aynscawait_es5.js"></script>
   </body>
</html>

Po uruchomieniu powyższej strony testowej zobaczysz dane wyjściowe w konsoli, jak pokazano poniżej

Operator potęgowania

** jest operatorem używanym do potęgowania w ES7. Poniższy przykład pokazuje działanie tego samego w ES7, a kod jest transponowany za pomocą babeljs.

Przykład

let sqr = 9 ** 2;
console.log(sqr);

Wynik

81

ES6 - Potęgowanie

let sqr = 9 ** 2;
console.log(sqr);

Aby przetransponować operator potęgowania, musimy zainstalować wtyczkę do zainstalowania w następujący sposób -

Komenda

npm install --save-dev babel-plugin-transform-exponentiation-operator

Dodaj szczegóły wtyczki do .babelrc plik w następujący sposób -

{
   "presets":[
      "es2015"
   ],
   "plugins": ["transform-exponentiation-operator"]
}

Komenda

npx babel exponeniation.js --out-file exponeniation_es5.js

BabelJS - ES5

"use strict";

var sqr = Math.pow(9, 2);
console.log(sqr);

Array.prototype.includes ()

Ta funkcja daje wartość true, jeśli przekazany do niej element jest obecny w tablicy i false, jeśli jest inaczej.

Przykład

let arr1 = [10, 6, 3, 9, 17];
console.log(arr1.includes(9));
let names = ['Siya', 'Tom', 'Jerry', 'Bean', 'Ben'];
console.log(names.includes('Tom'));
console.log(names.includes('Be'));

Wynik

true
true
false

Musimy ponownie użyć babel-polyfill tutaj jako includesjest metodą na tablicy i nie zostanie transpilowana. Potrzebujemy dodatkowego kroku, aby uwzględnić polifill, aby działał w starszych przeglądarkach.

ES6 - tablica. Zawiera

let arr1 = [10, 6, 3, 9, 17];
console.log(arr1.includes(9));
let names = ['Siya', 'Tom', 'Jerry', 'Bean', 'Ben'];
console.log(names.includes('Tom'));
console.log(names.includes('Be'));

Komenda

npx babel array_include.js --out-file array_include_es5.js

Babel-ES5

'use strict';

var arr1 = [10, 6, 3, 9, 17];
console.log(arr1.includes(9));
var names = ['Siya', 'Tom', 'Jerry', 'Bean', 'Ben'];
console.log(names.includes('Tom'));
console.log(names.includes('Be'));

Aby przetestować to w starszej przeglądarce, musimy użyć polyfill, jak pokazano poniżej -

<!DOCTYPE html>
<html>
   <head>
      <title>BabelJs Testing</title>
   </head>
   <body>
      <script src="node_modules\babel-polyfill\dist\polyfill.min.js" type="text/javascript"></script>
      <script type="text/javascript" src="array_include_es5.js"></script>
   </body>
</html>

Wynik