बैबेलजस - बैबल प्लगइन्स

BabelJS एक जावास्क्रिप्ट कंपाइलर है जो उपलब्ध प्रीसेट और प्लगइन्स के आधार पर दिए गए कोड के सिंटैक्स को बदलता है। बाबेल संकलन के प्रवाह में निम्नलिखित 3 भाग शामिल हैं -

  • parsing
  • transforming
  • printing

बबैल को दिया गया कोड वापस दिया गया है क्योंकि यह सिंटैक्स बदल गया है। हमने पहले से ही presets को .6 से es5 या इसके विपरीत कोड को संकलित करने के लिए .babelrc फ़ाइल में जोड़ा जा रहा है। प्रीसेट कुछ और नहीं बल्कि प्लगइन्स का एक सेट है। यदि प्रीसेट या प्लगइन्स का विवरण संकलन के दौरान नहीं दिया गया है तो बैबल कुछ भी नहीं बदलेगा।

आइए अब हम निम्नलिखित प्लगइन्स पर चर्चा करते हैं -

  • transform-class-properties
  • Transform-exponentiation-operator
  • For-of
  • वस्तु विश्राम और प्रसार
  • async/await

अब, हम एक प्रोजेक्ट सेटअप बनाएंगे और कुछ प्लगइन्स पर काम करेंगे, जो बेबल में प्लगइन्स की आवश्यकताओं की स्पष्ट समझ देगा।

आदेश

npm init

हमें babel - babel cli, babel core, babel-preset, आदि के लिए आवश्यक पैकेजों को स्थापित करना होगा।

बाबेल के लिए पैकेज ६

npm install babel-cli babel-core babel-preset-es2015 --save-dev

बाबेल के लिए पैकेज 7

npm install @babel/cli @babel/core @babel/preset-env --save-dev

अपने प्रोजेक्ट में एक js फाइल बनाएं और अपना js कोड लिखें।

वर्ग - रूपांतर-वर्ग-गुण

इस उद्देश्य के लिए नीचे दिए गए कोड देखें -

उदाहरण

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;
   }
}
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

अभी, हमने babel को कोई प्रीसेट या प्लगइन विवरण नहीं दिया है। यदि हम कमांड का उपयोग करके कोड ट्रांसपाइल करते हैं -

npx babel main.js --out-file main_out.js

main_out.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;
   }
}
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

जैसा है वैसा ही हमें कोड मिलेगा। अब हम प्रीसेट को जोड़ते हैं.babelrc फ़ाइल।

Note - बनाएं .babelrc अपने प्रोजेक्ट के रूट फोल्डर के अंदर फाइल करें।

.babelrc for babel 6

.babelrc for babel 7

{
   "presets":["@babel/env"]
}

हम पहले से ही प्रीसेट स्थापित कर चुके हैं; अब हम फिर से कमांड चलाते हैं -

npx babel main.js --out-file main_out.js

main_out.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;
}();

var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;

ईएस 6 में, क्लास सिंटैक्स निम्नानुसार है

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;
   }
}

कंस्ट्रक्टर है और वर्ग के सभी गुणों को इसके अंदर परिभाषित किया गया है। इंसेज़, हमें वर्ग गुणों को उस वर्ग के बाहर परिभाषित करने की आवश्यकता है जो हम ऐसा नहीं कर सकते।

उदाहरण

class Person {
   name = "Siya Kapoor";

   fullname = () => {
      return this.name;
   }
}
var a = new Person();
var persondet = a.fullname();
console.log("%c"+persondet, "font-size:25px;color:red;");

यदि हम उपरोक्त कोड को संकलित करने के लिए होते हैं, तो यह बेबल में एक त्रुटि है। इसके परिणामस्वरूप कोड संकलित नहीं हो रहा है।

इस काम को हम जिस तरह से करना चाहते हैं, करने के लिए हम बैबल-प्लगइन-ट्रांसफॉर्म-क्लास-प्रॉपर्टीज नामक बैबल प्लगइन का उपयोग कर सकते हैं। इसे काम करने के लिए, हमें इसे इस प्रकार स्थापित करना होगा -

बाबेल के लिए पैकेज ६

npm install --save-dev babel-plugin-transform-class-properties

बाबेल के लिए पैकेज 7

npm install --save-dev @babel/plugin-proposal-class-properties

Add the plugin to .babelrc file for babel 6 -

.babelrc for babel 7

{
   "plugins": ["@babel/plugin-proposal-class-properties"]
}

अब, हम फिर से कमांड चलाएंगे।

आदेश

npx babel main.js --out-file main_out.js

main.js

class Person {
   name = "Siya Kapoor";

   fullname = () => {
      return this.name;
   }
}
var a = new Person();
var persondet = a.fullname();
console.log("%c"+persondet, "font-size:25px;color:red;");

Compiled to main_out.js

class Person {
   constructor() {
      this.name = "Siya Kapoor";

      this.fullname = () => {
         return this.name;
      };
   }
}
var a = new Person();
var persondet = a.fullname();
console.log("%c"+persondet, "font-size:25px;color:red;");

Output

ब्राउज़र में उपयोग होने के बाद हमें प्राप्त होने वाला आउटपुट है -

प्रतिपादक संचालक - ट्रांसफॉर्मेशन-प्रतिपादक-संचालक

** ES7 में घातांक के लिए उपयोग किया जाने वाला ऑपरेटर है। निम्नलिखित उदाहरण ईएस 7 में उसी के काम को दर्शाता है। यह यह भी दर्शाता है कि बैबलज का उपयोग करके कोड ट्रांसपाइल कैसे किया जाता है।

उदाहरण

let sqr = 9 ** 2;
console.log("%c"+sqr, "font-size:25px;color:red;");

घातांक ऑपरेटर को बदलने के लिए, हमें एक प्लगइन की आवश्यकता है जो निम्नानुसार है -

Packages for babel 6

npm install --save-dev babel-plugin-transform-exponentiation-operator

Packages for babel 7

npm install --save-dev @babel/plugin-transform-exponentiation-operator

करने के लिए प्लगइन विवरण जोड़ें .babelrc फ़ाइल 6 के लिए इस प्रकार है -

{
   "plugins": ["transform-exponentiation-operator"]
}

.babelrc for babel 7

{
   "plugins": ["@babel/plugin-transform-exponentiation-operator"]
}

command

npx babel exponeniation.js --out-file exponeniation_out.js

exponeniation_out.js

let sqr = Math.pow(9, 2);
console.log("%c" + sqr, "font-size:25px;color:red;");

Output

के लिए

Babel6 और 7 में प्लगइन्स के लिए आवश्यक पैकेज निम्नानुसार हैं -

Babel6

npm install --save-dev babel-plugin-transform-es2015-for-of

कोलाहल 7

npm install --save-dev @babel/plugin-transform-for-of

.babelrc for babel6

{
   "plugins": ["transform-es2015-for-of"]
}

.babelrc for babel7

{
   "plugins": ["@babel/plugin-transform-for-of"]
}

forof.js

let foo = ["PHP", "C++", "Mysql", "JAVA"];
for (var i of foo) {
   console.log(i);
}

आदेश

npx babel forof.js --out-file forof_es5.js

Forof_es5.js

let foo = ["PHP", "C++", "Mysql", "JAVA"];
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;

try {
   for (var _iterator = foo[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
      var i = _step.value;

      console.log(i);
   }
} catch (err) {
   _didIteratorError = true;
   _iteratorError = err;
} finally {
   try {
      if (!_iteratorNormalCompletion && _iterator.return) {
         _iterator.return();
      }
   } finally {
      if (_didIteratorError) {
         throw _iteratorError;
      }
   }
}

Output

ऑब्जेक्ट बाकी फैल गया

Babel6 और 7 में प्लगइन्स के लिए आवश्यक पैकेज निम्नानुसार हैं -

कोलाहल ६

npm install --save-dev babel-plugin-transform-object-rest-spread

कोलाहल 7

npm install --save-dev @babel/plugin-proposal-object-rest-spread

.babelrc for babel6

{
   "plugins": ["transform-object-rest-spread"]
}

.babelrc for babel7

{
   "plugins": ["@babel/plugin-proposal-object-rest-spread"]
}

o.js

let { x1, y1, ...z1 } = { x1: 11, y1: 12, a: 23, b: 24 };
console.log(x1);
console.log(y1);
console.log(z1);

let n = { x1, y1, ...z1};
console.log(n);

आदेश

npx babel o.js --out-file o_es5.js

o_es5.js

var _extends = Object.assign || function (target) {
   for (var i = 1; i < arguments.length; i++) {
      var source = arguments[i]; for (var key in source) {
         if (Object.prototype.hasOwnProperty.call(source, key)) {
            target[key] = source[key]; 
         } 
      } 
   } 
   return target; 
};

function _objectWithoutProperties(obj, keys) {
   var target = {};
   for (var i in obj) {
      if (keys.indexOf(i) >= 0) continue;
      if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;
      target[i] = obj[i];
   }
   return target;
}

let _x1$y1$a$b = { x1: 11, y1: 12, a: 23, b: 24 },
   { x1, y1 } = _x1$y1$a$b,
   z1 = _objectWithoutProperties(_x1$y1$a$b, ["x1", "y1"]);
console.log(x1);
console.log(y1);
console.log(z1);

let n = _extends({ x1, y1 }, z1);
console.log(n);

Output

async / इंतजार

हमें बाबेल 6 के लिए निम्नलिखित पैकेजों की आवश्यकता है -

npm install --save-dev babel-plugin-transform-async-to-generator

बाबेल के लिए पैकेज 7

npm install --save-dev @babel/plugin-transform-async-to-generator

.babelrc for babel 6

{
   "plugins": ["transform-async-to-generator"]
}

.babelrc for babel 7

{
   "plugins": ["@babel/plugin-transform-async-to-generator"]
}

async.js

let timer = () => {
   return new Promise(resolve => {
      setTimeout(() => {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
let out = async () => {
   let msg = await timer();
   console.log(msg);
   console.log("hello after await");
};

out();

आदेश

npx babel async.js --out-file async_es5.js

async_es5.js

function _asyncToGenerator(fn) {
   return function () {
      var gen = fn.apply(this, arguments);
      return new Promise(function (resolve, reject) {
         function step(key, arg) {
            try {
               var info = gen[key](arg);
               var value = info.value; 
            } catch (error) {
               reject(error);
               return; 
            } if (info.done) {
               resolve(value); 
            } else {
               return Promise.resolve(value).then(function (value) {
                  step("next", value);
               },
               function (err) {
                  step("throw", err); }); 
            }
         } return step("next"); 
      });
   };
}

let timer = () => {
   return new Promise(resolve => {
      setTimeout(() => {
         resolve("Promise resolved after 5 seconds");
      }, 5000);
   });
};
let out = (() => {
   var _ref = _asyncToGenerator(function* () {
      let msg = yield timer();
      console.log(msg);
      console.log("hello after await");
   });

   return function out() {
      return _ref.apply(this, arguments);
   };
})();
out();

हमें उसी के लिए पॉलीफिल का उपयोग करना होगा क्योंकि यह उन ब्राउज़रों में काम नहीं करेगा जहां वादे समर्थित नहीं हैं।

Output