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/.