BabelJS - Arbeiten mit Babel und JSX
In diesem Kapitel werden wir die Arbeit mit JSX und Babel verstehen. Bevor wir auf die Details eingehen, lassen Sie uns verstehen, was JSX ist.
Was ist JSX?
JSX ist ein JavaScript-Code mit einer Kombination aus XML-Syntax. Das JSX-Tag enthält Tag-Namen, Attribute und untergeordnete Elemente, die es wie XML aussehen lassen.
React verwendet JSX für Vorlagen anstelle von normalem JavaScript. Es ist nicht notwendig, es zu verwenden. Es folgen jedoch einige Profis, die damit einhergehen.
Es ist schneller, da es beim Kompilieren von Code in JavaScript eine Optimierung durchführt.
Es ist auch typsicher und die meisten Fehler können beim Kompilieren abgefangen werden.
Es macht es einfacher und schneller, Vorlagen zu schreiben, wenn Sie mit HTML vertraut sind.
Wir haben Babel 6 im Projekt-Setup verwendet. Wenn Sie zu Babel 7 wechseln möchten, installieren Sie die erforderlichen Babel-Pakete mit@babel/babel-package-name.
Wir werden ein Projekt-Setup erstellen und Webpack verwenden, um jsx zu kompilieren und mit Babel auf normales JavaScript zu reagieren.
Führen Sie die folgenden Befehle für die Installation von Babel, React und Webpack aus, um das Projekt-Setup zu starten.
Befehl
npm init
Jetzt installieren wir die notwendigen Pakete, mit denen wir arbeiten müssen - babel, webpack und jsx -
npm install --save-dev webpack
npm install --save-dev webpack-cli
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-es2015
npm install --save-dev babel-preset-react
npm install --save-dev react
npm install --save-dev react-dom
Hier ist die package.json nach der Installation -
Jetzt wird eine webpack.config.js-Datei erstellt, die alle Details enthält, um die js-Dateien zu bündeln und mit babel in es5 zu kompilieren.
Um Webpack mit Server auszuführen, gibt es einen sogenannten Webpack-Server. Wir haben den Befehl "Publizieren" hinzugefügt. Dieser Befehl startet den Webpack-Dev-Server und aktualisiert den Pfad, in dem die endgültigen Dateien gespeichert sind. Im Moment ist der Pfad, den wir zum Aktualisieren der endgültigen Dateien verwenden werden, der Ordner / dev.
Um Webpack zu verwenden, müssen wir den folgenden Befehl ausführen:
npm run publish
Wir werden das schaffen webpack.config.js Dateien, die die Konfigurationsdetails enthalten, damit das Webpack funktioniert.
Die Details in der Datei sind wie folgt:
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|jsx)$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['es2015','react']
}
}
]
}
};
Die Struktur der Datei ist wie oben gezeigt. Es beginnt mit dem Pfad, der die aktuellen Pfaddetails angibt.
var path = require('path'); //gives the current path
Als nächstes folgt das Objekt module.exports mit Eigenschafteneintrag, Ausgabe und Modul.
Der Einstieg ist der Startpunkt. Hier müssen wir die wichtigsten js-Dateien angeben, die wir kompilieren möchten.
entry: {
app: './src/main.js'
},
path.resolve(_dirname, ‘src/main.js’) - sucht nach dem src-Ordner im Verzeichnis und main.js in diesem Ordner.
Ausgabe
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
Die Ausgabe ist ein Objekt mit Pfad- und Dateinamenangaben. Der Pfad enthält den Ordner, in dem die kompilierte Datei gespeichert wird, und der Dateiname gibt den Namen der endgültigen Datei an, die in Ihrer Datei verwendet werden soll.html Datei.
Modul
module: {
rules: [
{
test:/\.(js|jsx)$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['es2015','react']
}
}
]
}
Das Modul ist ein Objekt mit Regeldetails, das Eigenschaften hat, z. B. test, include, loader, query.
Der Test enthält Details zu allen js-Dateien, die mit .js und .jsx enden. Er hat das Muster, das am Ende des angegebenen Einstiegspunkts nach .js und .jsx sucht.
Include weist den Ordner an, der zum Suchen der Dateien verwendet werden soll.
Loader verwendet Babel-Loader zum Kompilieren von Code.
Die Abfrage verfügt über Eigenschaftsvoreinstellungen, dh ein Array mit dem Wert env - es5 oder es6 oder es7. Wir haben es2015 verwendet und reagieren als Voreinstellung.
Ordner erstellen src/. Hinzufügen main.js und App.jsx drin.
App.jsx
import React from 'react';
class App extends React.Component {
render() {
var style = {
color: 'red',
fontSize: 50
};
return (
<div style={style}>
Hello World!!!
</div>
);
}
}
export default App;
main.js
import React from 'react';
import ReactDOM from 'react-dom';
import App from './App.jsx';
ReactDOM.render(
, document.getElementById('app'));
Führen Sie den folgenden Befehl aus, um die .js-Datei zu bündeln und mithilfe von Voreinstellungen zu konvertieren es2015 und react.
Befehl
npm run pack
Hinzufügen main_bundle.js aus dem dev-Ordner nach index.html - -
<!DOCTYPE html>
<html lang = "en">
<head>
<meta charset = "UTF-8">
<title>React App</title>
</head>
<body>
<div id = "app"></div>
<script src = "dev/main_bundle.js"></script>
</body>
</html>
Befehl
npm run publish