BabelJS - wykonanie kodu ES6
BabelJSto transpiler JavaScript, który konwertuje nowe funkcje dodane do JavaScript do ES5 lub reaguje na podstawie podanego ustawienia wstępnego lub wtyczki. ES5 jest jedną z najstarszych form JavaScript i jest obsługiwana, aby działać w nowych i starych przeglądarkach bez żadnych problemów. W większości przykładów w tym samouczku przetransponowaliśmy kod do ES5.
Widzieliśmy wiele funkcji, takich jak funkcje strzałek, klasy, obietnice, generatory, funkcje asynchroniczne itp. Dodane do ES6, ES7 i ES8. Gdy którakolwiek z nowo dodanych funkcji jest używana w starych przeglądarkach, generuje błędy. BabelJS pomaga w kompilacji kodu, który jest wstecznie kompatybilny ze starszymi przeglądarkami. Widzieliśmy, że ES5 działa doskonale na starszych przeglądarkach bez żadnych problemów. Biorąc pod uwagę szczegóły środowiska projektu, jeśli wymagane jest, aby działało na starszych przeglądarkach, możemy użyć dowolnej nowej funkcji w naszym projekcie i skompilować kod do ES5 za pomocą babeljs i używać go bez żadnych problemów w dowolnej przeglądarce.
Rozważmy następujący przykład, aby to zrozumieć.
Przykład
<!DOCTYPE html>
<html>
<head>
<title>BabelJs Testing</title>
</head>
<body>
<script type="text/javascript" src="index.js"></script>
</body>
</html>
plik index.js
var _foo = () => {
return "Hello World"
};
alert(_foo());
Wynik
Po uruchomieniu powyższego html w przeglądarce Chrome otrzymujemy następujące dane wyjściowe -
Gdy kod HTML jest uruchamiany w przeglądarce Firefox, generuje następujące dane wyjściowe -
Gdy ten sam kod HTML jest uruchamiany w przeglądarce Internet Explorer, generuje następujący błąd składni -
Użyliśmy funkcji strzałki ES6; to samo nie działa we wszystkich przeglądarkach, jak pokazano powyżej. Aby to działało, mamy BabelJS do skompilowania kodu do ES5 i użycia go we wszystkich przeglądarkach.
Skompiluje plik js do es5 przy użyciu babeljs i sprawdzi ponownie w przeglądarkach.
W pliku html użyjemy index_new.js, jak pokazano poniżej -
<!DOCTYPE html>
<html>
<head>
<title>BabelJs Testing</title>
</head>
<body>
<script type="text/javascript" src="index_new.js"></script>
</body>
</html>
index_new.js
"use strict";
var _foo = function _foo() {
return "Hello World";
};
alert(_foo());