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