BabelJS - przegląd

BabelJSto transpiler JavaScript, który przenosi nowe funkcje do starego standardu. Dzięki temu funkcje można bezproblemowo uruchamiać zarówno w starych, jak i nowych przeglądarkach. Australijski programista Sebastian McKenzie założył BabelJS.

Dlaczego BabelJS?

JavaScript to język rozumiany przez przeglądarkę. Do uruchamiania naszych aplikacji używamy różnych przeglądarek - Chrome, Firefox, Internet Explorer, Microsoft Edge, Opera, UC itp. ECMA Script to specyfikacja języka JavaScript; ECMA Script 2015 ES6 to stabilna wersja, która działa dobrze we wszystkich nowych i starych przeglądarkach.

Po ES5 mieliśmy ES6, ES7 i ES8. ES6 wydany z wieloma nowymi funkcjami, które nie są w pełni obsługiwane przez wszystkie przeglądarki. To samo dotyczy ES7, ES8 i ESNext (kolejna wersja ECMA Script). Nie jest teraz pewne, kiedy będzie możliwe, aby wszystkie przeglądarki były kompatybilne ze wszystkimi wydanymi wersjami ES.

O ile planujemy używać funkcji ES6, ES7 lub ES8 do pisania naszego kodu, będzie on miał tendencję do awarii w niektórych starych przeglądarkach z powodu braku obsługi nowych zmian. Dlatego jeśli chcemy wykorzystać nowe funkcje ECMA Script w naszym kodzie i chcemy go uruchamiać na wszystkich możliwych przeglądarkach, potrzebujemy narzędzia, które skompiluje nasz ostateczny kod w ES5.

Babelrobi to samo i nazywa się transpilerem, który transponuje kod do żądanej wersji skryptu ECMA. Posiada funkcje, takie jak ustawienia wstępne i wtyczki, które konfigurują wersję ECMA potrzebną do transpozycji naszego kodu. Dzięki Babel programiści mogą pisać swój kod przy użyciu nowych funkcji JavaScript. Użytkownicy mogą przetransponować kody za pomocą Babel; kody mogą być później używane w dowolnej przeglądarce bez żadnych problemów.

The following table lists down the features available in ES6, ES7 and ES8 −

funkcje Wersja skryptu ECMA
Niech + Konst ES6
Funkcje strzałek ES6
Zajęcia ES6
Obietnice ES6
Generatory ES6
Iteratory ES6
Moduły ES6
Destrukturyzacja ES6
Literały szablonów ES6
Ulepszony obiekt ES6
Właściwości domyślne, odpoczynku i spreadu ES6
Async - Await ES7
Operator potęgowania ES7
Array.prototype.includes () ES7
Wypełnienie strun ES8

BabelJS zarządza następującymi dwiema częściami -

  • transpiling
  • polyfilling

Co to jest Babel-Transpiler?

Babel-transpiler konwertuje składnię współczesnego JavaScript do postaci, która może być łatwo zrozumiała przez starsze przeglądarki. Na przykład: arrow function, const, let klasy zostaną przekonwertowane na function, var itd. Tutaj składnia, tj. Funkcja strzałkowa, jest konwertowana na normalną funkcję, zachowując tę ​​samą funkcjonalność w obu przypadkach.

Co to jest Babel-polyfill?

W JavaScript dodano nowe funkcje, takie jak obietnice, mapy i obejmuje. Funkcje mogą być używane w tablicy; to samo, gdy jest używane i transponowane za pomocą babel nie zostanie przekonwertowane. W przypadku, gdy nową funkcją jest metoda lub obiekt, musimy użyć Babel-polyfill wraz z transpilingiem, aby działał na starszych przeglądarkach.

Oto lista funkcji ECMA Script dostępnych w JavaScript, które można przetransponować i wypełnić -

  • Classes
  • Decorators
  • Const
  • Modules
  • Destructing
  • Parametry domyślne
  • Obliczone nazwy właściwości
  • Obiekt spoczywa / rozkłada
  • Funkcje asynchroniczne
  • Funkcje strzałek
  • Parametry odpoczynku
  • Spread
  • Literały szablonów

ECMA Script features that can be polyfilled −

  • Promises
  • Map
  • Set
  • Symbol
  • Weakmap
  • Weakset
  • includess
  • Array.from, Array.of, Array # find, Array.buffer, Array # findIndex
  • Object.assign,Object.entries,Object.values

Funkcje BabelJS

W tej sekcji dowiemy się o różnych funkcjach BabelJS. Poniżej przedstawiono najważniejsze podstawowe cechy BabelJS -

Babel-Plugins

Wtyczki i ustawienia wstępne to szczegóły konfiguracyjne Babel do transpilacji kodu. Babel obsługuje szereg wtyczek, z których można korzystać indywidualnie, jeśli znamy środowisko, w którym będzie wykonywany kod.

Babel-Presets

Ustawienia wstępne Babel to zestaw wtyczek, tj. Szczegóły konfiguracji transpilera babel, które instruują Babel do transpilacji w określonym trybie. Musimy użyć presetów, które mają środowisko, w którym chcemy konwertować kod. Na przykład ustawienie wstępne es2015 przekształci kod na es5 .

Babel-Polyfills

Istnieją pewne funkcje, takie jak metody i obiekty, których nie można transponować. W takich przypadkach możemy skorzystać z babel-polyfill, aby ułatwić korzystanie z funkcji w dowolnej przeglądarce. Rozważmy przykład obietnic; aby funkcja działała w starszych przeglądarkach, musimy używać polyfillów.

Babel-Polyfills

Babel-cli zawiera kilka poleceń, w których kod można łatwo skompilować w wierszu poleceń. Posiada również funkcje, takie jak wtyczki i ustawienia wstępne, których można używać wraz z poleceniem, ułatwiając transpozycję kodu za jednym razem.

Zalety korzystania z BabelJS

W tej sekcji dowiemy się o różnych zaletach związanych z korzystaniem z BabelJS -

  • BabelJS zapewnia wsteczną kompatybilność wszystkich nowo dodanych funkcji JavaScript i może być używany w dowolnej przeglądarce.

  • BabelJS ma możliwość transpile, aby przyjąć następną nadchodzącą wersję JavaScript - ES6, ES7, ESNext itp.

  • BabelJS może być używany razem z gulp, webpack, flow, reagować, maszynopisem itp., Co czyni go bardzo potężnym i może być używany w dużych projektach, ułatwiając życie programistom.

  • BabelJS współpracuje również ze składniąreak JSX i może być skompilowany w formie JSX.

  • BabelJS obsługuje wtyczki, polyfills, babel-cli, co ułatwia pracę z dużymi projektami.

Wady korzystania z BabelJS

W tej sekcji poznamy różne wady korzystania z BabelJS -

  • Kod BabelJS zmienia składnię podczas transpilacji, co sprawia, że ​​kod jest trudny do zrozumienia po wydaniu na produkcję.

  • Kod transpilowany jest większy w porównaniu z kodem oryginalnym.

  • Nie wszystkie ES6 / 7/8 lub nadchodzące nowe funkcje można przetransponować i musimy używać polyfill, aby działał na starszych przeglądarkach.

Oto oficjalna strona babeljs https://babeljs.io/.