BabelJS - BabelJS और गुलप के साथ काम करना
इस अध्याय में, हम babel और gulp का उपयोग करके प्रोजेक्ट सेटअप बनाएंगे। गुलप एक टास्क रनर है जो Node.js को एक प्लेटफॉर्म के रूप में उपयोग करता है। गुल उन कार्यों को चलाएगा जो es6 से es5 तक जावास्क्रिप्ट फ़ाइलों को ट्रांसपाइल करेगा और एक बार किए जाने के बाद परिवर्तनों का परीक्षण करने के लिए सर्वर शुरू करेगा। हमने प्रोजेक्ट सेटअप में बैबल 6 का उपयोग किया है। यदि आप बाबेल 7 पर स्विच करना चाहते हैं, तो बाबेल के आवश्यक पैकेजों का उपयोग करके स्थापित करें@babel/babel-package-name।
हम पहले npm कमांड का उपयोग करके प्रोजेक्ट बनाएंगे और शुरू करने के लिए आवश्यक पैकेज स्थापित करेंगे।
आदेश
npm init
हमने gulpbabel नामक एक फोल्डर बनाया है। इसके अलावा, हम gulp और अन्य आवश्यक निर्भरताएँ स्थापित करेंगे।
आदेश
npm install gulp --save-dev
npm install gulp-babel --save-dev
npm install gulp-connect --save-dev
npm install babel-preset-env --save-dev
npm install babel-core --save-dev
हम प्रीसेट वातावरण विवरण इसमें जोड़ देंगे .babelrc फाइल इस प्रकार है
gulpfile.js
var gulp =require('gulp');
var babel =require('gulp-babel');
var connect = require("gulp-connect");
gulp.task('build', () => {
gulp.src('src/./*.js')
.pipe(babel())
.pipe(gulp.dest('./dev'))
});
gulp.task('watch', () => {
gulp.watch('./*.js', ['build']);
});
gulp.task("connect", function () {
connect.server({
root: ".",
livereload: true
});
});
gulp.task('start', ['build', 'watch', 'connect']);
हमने gulp में तीन कार्य बनाए हैं, ['build', 'watch', 'connect']। Src फोल्डर में उपलब्ध सभी js फाइलें इस प्रकार बबेल का उपयोग करके es5 में बदल जाएगी -
gulp.task('build', () => {
gulp.src('src/./*.js')
.pipe(babel())
.pipe(gulp.dest('./dev'))
});
अंतिम परिवर्तन देव फ़ोल्डर में संग्रहीत हैं। बैबेल प्रीसेट विवरण का उपयोग करता है.babelrc। यदि आप किसी अन्य प्रीसेट में बदलना चाहते हैं, तो आप विवरण को बदल सकते हैं.babelrc फ़ाइल।
अब es6 जावास्क्रिप्ट और रन का उपयोग करके src फोल्डर में एक .js फ़ाइल बनाएंगे gulp start परिवर्तनों को निष्पादित करने के लिए कमांड।
src/main.js
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;
}
}
Command: gulp start
dev/main.js
यह बाबेल का उपयोग कर ट्रांसप्लड किया गया है
"use strict";
var _createClass = function () {
function defineProperties(target, props) {
for (var i = 0; i <props.length; i++) {
var descriptor = props[i];
descriptor.enumerable = descriptor.enumerable || false;
descriptor.configurable = true;
if ("value" in descriptor) descriptor.writable = true;
Object.defineProperty(target, descriptor.key, descriptor);
}
}
return function (Constructor, protoProps, staticProps) {
if (protoProps) defineProperties(Constructor.prototype, protoProps);
if (staticProps) defineProperties(Constructor, staticProps);
return Constructor;
};
}();
function _classCallCheck(instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
}
var Person = function () {
function Person(fname, lname, age, address) {
_classCallCheck(this, Person);
this.fname = fname;
this.lname = lname;
this.age = age;
this.address = address;
}
_createClass(Person, [{
key: "fullname",
get: function get() {
return this.fname + "-" + this.lname;
}
}]);
return Person;
}();
Index.html
यह प्रयोग किया जाता है transpiled dev/main.js -
<html>
<head></head>
<body>
<script type="text/javascript" src="dev/main.js"></script>
<h1 id="displayname"></h1>
<script type="text/javascript">
var a = new Student("Siya", "Kapoor", "15", "Mumbai");
var studentdet = a.fullname;
document.getElementById("displayname").innerHTML = studentdet;
</script>
</body>
</html>
Output