BabelJS - Praca z Babel i Webpack
Webpack to pakiet modułów, który pakuje wszystkie moduły z zależnościami - js, style, obrazy, itp. Do statycznych zasobów .js, .css, .jpg, .png, itd. Webpack zawiera gotowe ustawienia, które pomagają w kompilacji do wymaganej postaci. Na przykład, reakcja preset, która pomaga uzyskać ostateczny wynik w postaci reago, es2015 lub preset env, który pomaga skompilować kod w ES5 lub 6 lub 7, itd. Użyliśmy babel 6 w konfiguracji projektu. Jeśli chcesz przełączyć się na babel7, zainstaluj wymagane pakiety babel używając @ babel / babel-nazwa-pakietu.
Tutaj omówimy konfigurację projektu za pomocą babel i webpacka. Utwórz folder o nazwie i otwórz go w środowisku Visual Studio IDE.
Aby utworzyć konfigurację projektu, uruchom npm initbabelwebpack w następujący sposób -
Oto plik package.json utworzony po inicjalizacji npm -
Teraz zainstalujemy niezbędne pakiety, których potrzebujemy do pracy z babel i webpack.
npm install --save-dev webpack
npm install --save-dev webpack-dev-server
npm install --save-dev babel-core
npm install --save-dev babel-loader
npm install --save-dev babel-preset-env
Oto plik Package.json po instalacji -
Teraz utworzymy plik webpack.config.js, który będzie zawierał wszystkie szczegóły potrzebne do spakowania plików js. Te pliki zostaną skompilowane do es5 przy użyciu babel.
Aby uruchomić webpack na serwerze, używamy serwera webpack. Poniżej znajdują się szczegóły dodane do niego -
Dodaliśmy polecenie publikowania, które uruchomi serwer webpack-dev-server i zaktualizuje ścieżkę, w której przechowywane są końcowe pliki. W tej chwili ścieżką, której będziemy używać do aktualizacji plików końcowych, jest folder / dev.
Aby użyć webpacka, musimy uruchomić następującą komendę -
npm run publish
Najpierw musimy utworzyć pliki webpack.config.js. Będą one zawierać szczegóły konfiguracji do działania pakietu internetowego.
Szczegóły w pliku są następujące -
var path = require('path');
module.exports = {
entry: {
app: './src/main.js'
},
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
mode:'development',
module: {
rules: [
{
test: /\.js$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['env']
}
}
]
}
};
Struktura pliku jest taka, jak pokazano powyżej. Zaczyna się od ścieżki h, która zawiera szczegóły dotyczące bieżącej ścieżki.
var path = require('path'); //gives the current path
Następny jest obiekt module.exports, który zawiera właściwości wpis, dane wyjściowe i moduł. Wpis jest punktem początkowym. Tutaj musimy podać główne pliki js, które mają zostać skompilowane.
entry: {
app: './src/main.js'
},
path.resolve(_dirname, ‘src/main.js’) - wyszuka folder src w katalogu, a main.js w tym folderze.
Wynik
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
Dane wyjściowe to obiekt ze szczegółami ścieżki i nazwy pliku. Ścieżka będzie zawierała folder, w którym będzie przechowywany skompilowany plik, a nazwa pliku wskaże nazwę pliku końcowego, który ma być użyty w pliku .html.
moduł
module: {
rules: [
{
test: /\.js$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['env']
}
}
]
}
Moduł to obiekt ze szczegółami reguł. Ma następujące właściwości -
- test
- include
- loader
- query
Test będzie zawierał szczegóły wszystkich plików js kończących się na .js. Ma wzorzec, który będzie szukał .js na końcu w podanym punkcie wejścia.
Uwzględnij instruuje folder używany z plikami, które mają być przeglądane.
Program ładujący używa programu ładującego Babel do kompilowania kodów.
Zapytanie ma predefiniowane ustawienia właściwości, które są tablicą o wartości env - es5, es6 lub es7.
Utwórz w nim folder src i main.js ; napisz swój kod js w ES6. Później uruchom polecenie, aby zobaczyć, jak kompiluje się do es5 przy użyciu pakietu webpack i babel.
src/main.js
let add = (a,b) => {
return a+b;
};
let c = add(10, 20);
console.log(c);
Uruchom polecenie -
npm run pack
Skompilowany plik wygląda następująco -
dev/main_bundle.js
!function(e) {
var t = {};
function r(n) {
if(t[n])return t[n].exports;var o = t[n] = {i:n,l:!1,exports:{}};
return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports
}
r.m = e,r.c = t,r.d = function(e,t,n) {
r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})
},
r.r = function(e) {
"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})
},
r.t = function(e,t) {
if(1&t&&(e = r(e)),8&t)return e;
if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;
var n = Object.create(null);
if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)r.d(n,o,function(t) {return e[t]}.bind(null,o));
return n
},
r.n = function(e) {
var t = e&&e.__esModule?function() {return e.default}:function() {return e};
return r.d(t,"a",t),t
},
r.o = function(e,t) {return Object.prototype.hasOwnProperty.call(e,t)},
r.p = "",r(r.s = 0)
}([function(e,t,r) {"use strict";var n = function(e,t) {return e+t}(10,20);console.log(n)}]);
!function(e) {
var t = {};
function r(n) {
if(t[n])return t[n].exports;
var o = t[n] = {i:n,l:!1,exports:{}};
return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports
}
r.m = e,r.c = t,r.d = function(e,t,n) {
r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})
},
r.r = function(e) {
"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})
},
r.t = function(e,t) {
if(1&t&&(e=r(e)),
8&t)return e;
if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;
var n = Object.create(null);
if(
r.r(n),
Object.defineProperty(n,"default",{enumerable:!0,value:e}),
2&t&&"string"!=typeof e
)
for(var o in e)r.d(n,o,function(t) {return e[t]}.bind(null,o));
return n
},
r.n = function(e) {
var t = e&&e.__esModule?function() {return e.default}:function() {return e};
return r.d(t,"a",t),t
},
r.o = function(e,t) {
return Object.prototype.hasOwnProperty.call(e,t)
},
r.p = "",r(r.s = 0)
}([function(e,t,r) {
"use strict";
var n = function(e,t) {return e+t}(10,20);
console.log(n)
}]);
Kod jest kompilowany, jak pokazano powyżej. Webpack dodaje kod, który jest wymagany wewnętrznie, a kod z main.js jest widoczny na końcu. Pocieszaliśmy wartość, jak pokazano powyżej.
Dodaj końcowy plik js w pliku .html w następujący sposób -
<html>
<head></head>
<body>
<script type="text/javascript" src="dev/main_bundle.js"></script>
</body>
</html>
Uruchom polecenie -
npm run publish
Aby sprawdzić wyjście, możemy otworzyć plik w -
http://localhost:8080/
Otrzymujemy wartość konsoli, jak pokazano powyżej. Teraz spróbujmy skompilować się do pojedynczego pliku przy użyciu pakietu webpack i babel.
Będziemy używać pakietu webpack do łączenia wielu plików js w jeden plik. Babel zostanie użyty do skompilowania kodu es6 do es5.
Teraz mamy 2 pliki js w folderze src / - main.js i Person.js w następujący sposób -
person.js
export 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;
}
}
Użyliśmy eksportu, aby użyć szczegółów klasy Person.
main.js
import {Person} from './person'
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;
console.log(persondet);
W main.js zaimportowaliśmy Person ze ścieżki pliku.
Note- Nie musimy dołączać pliku person.js, ale tylko nazwę pliku. Stworzyliśmy obiekt klasy Person i uspokoiliśmy szczegóły, jak pokazano powyżej.
Webpack połączy się person.js i main.js i zaktualizuj w dev/main_bundle.jsjako jeden plik. Uruchom polecenienpm run publish aby sprawdzić wyjście w przeglądarce -