बेबेलजेएस - बैबेल और वेबपैक के साथ काम करना

वेबपैक एक मॉड्यूल बंडलर है जो सभी मॉड्यूल को निर्भरता के साथ पैक करता है - js, स्टाइल, चित्र इत्यादि। उदाहरण के लिए, पूर्व निर्धारित करें जो प्रतिक्रिया फॉर्म में अंतिम आउटपुट प्राप्त करने में मदद करता है, es2015 या एनवी प्रीसेट जो ईएस 5 या 6 या 7 में कोड को संकलित करने में मदद करता है, आदि। हमने प्रोजेक्ट सेटअप में बैबल 6 का उपयोग किया है। यदि आप babel7 पर जाना चाहते हैं, तो @ babel / babel-package-name का उपयोग करके बेबल के आवश्यक पैकेजों को स्थापित करें।

यहां, हम बेबल और वेबपैक का उपयोग करके प्रोजेक्ट सेटअप पर चर्चा करेंगे। नामक एक फ़ोल्डर बनाएँ और दृश्य स्टूडियो आईडीई में समान खोलें।

प्रोजेक्ट सेटअप बनाने के लिए, npm initbabelwebpack को निम्न प्रकार से चलाएं -

यहाँ पैकेज है। Npm init के बाद बनाया गया।

अब, हम बेबल और वेबपैक के साथ काम करने के लिए आवश्यक पैकेज स्थापित करेंगे।

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

यहाँ स्थापना के बाद Package.json है -

अब, हम एक webpack.config.js फ़ाइल बनाएंगे, जिसमें js फ़ाइलों को बंडल करने के लिए सभी विवरण होंगे। इन फ़ाइलों को इसे bab5 का उपयोग करके es5 में संकलित किया जाएगा।

सर्वर का उपयोग करके वेबपैक चलाने के लिए, हम वेबपैक-सर्वर का उपयोग करते हैं। निम्नलिखित विवरण इसमें जोड़े गए हैं -

हमने प्रकाशित कमांड जोड़ दिया है जो वेबपैक-देव-सर्वर शुरू करेगा और उस पथ को अपडेट करेगा जहां अंतिम फाइलें संग्रहीत हैं। अभी हम अंतिम फ़ाइलों को अपडेट करने के लिए जिस पथ का उपयोग करने जा रहे हैं वह / dev फ़ोल्डर है।

वेबपैक का उपयोग करने के लिए, हमें निम्नलिखित कमांड चलाने की आवश्यकता है -

npm run publish

सबसे पहले हमें webpack.config.js फाइलें बनाने की जरूरत है। ये काम करने के लिए webpack के लिए विन्यास विवरण होगा।

फाइल का विवरण इस प्रकार है -

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

फ़ाइल की संरचना ऊपर बताई गई है। यह theh पाथ से शुरू होता है, जो वर्तमान पाथ विवरण देता है।

var path = require('path'); //gives the current path

अगला मॉड्यूल.एक्सपोर्ट ऑब्जेक्ट है, जिसमें गुण प्रविष्टि, आउटपुट और मॉड्यूल हैं। प्रवेश प्रारंभ बिंदु है। यहां, हमें मुख्य जेएस फाइलें देने की जरूरत है जिन्हें संकलित किया जाना है।

entry: {
   app: './src/main.js'
},

path.resolve(_dirname, ‘src/main.js’) - निर्देशिका में src फ़ोल्डर और उस फ़ोल्डर में main.js के लिए दिखेगा।

उत्पादन

output: {
   path: path.resolve(__dirname, 'dev'),
   filename: 'main_bundle.js'
},

आउटपुट पथ और फ़ाइल नाम के विवरण के साथ एक वस्तु है। पथ उस फ़ोल्डर को रखेगा जिसमें संकलित फ़ाइल रखी जाएगी और फ़ाइल नाम आपके .html फ़ाइल में उपयोग की जाने वाली अंतिम फ़ाइल का नाम बताएगा।

मापांक

module: {
   rules: [
      {
         test: /\.js$/,
         include: path.resolve(__dirname, 'src'),
         loader: 'babel-loader',
         query: {
            presets: ['env']
         }
      }
   ]
}
  • नियम के विवरण के साथ मॉड्यूल एक वस्तु है। इसके निम्नलिखित गुण हैं -

    • test
    • include
    • loader
    • query
  • टेस्ट .js के साथ समाप्त होने वाली सभी js फाइलों का विवरण रखेगा। इसमें पैटर्न है, जो दिए गए प्रविष्टि बिंदु में .js के लिए दिखेगा।

  • शामिल फ़ाइलों पर उपयोग किए जाने वाले फ़ोल्डर को देखने के लिए निर्देश देता है।

  • लोडर कोड संकलन के लिए बैबल- लोडर का उपयोग करता है।

  • क्वेरी में प्रॉपर्टी प्रीसेट होते हैं, जो कि एवी के साथ एक सरणी है - es5 या es6 या es7।

इसमें फ़ोल्डर src और main.js बनाएं ; ES6 में अपना js कोड लिखें। बाद में, यह देखने के लिए कमांड को चलाएं कि यह वेबपैक और बैबेल का उपयोग करके es5 के लिए संकलित हो रहा है।

src/main.js

let add = (a,b) => {
   return a+b;
};
let c = add(10, 20);
console.log(c);

कमांड चलाएं -

npm run pack

संकलित फ़ाइल इस प्रकार है -

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

जैसा कि ऊपर दिखाया गया है कोड संकलित है। Webpack कुछ कोड जोड़ता है जो आंतरिक रूप से आवश्यक है और main.js से कोड अंत में देखा जाता है। हमने ऊपर दिखाए अनुसार मान को सांत्वना दी है।

अंतिम। Js फ़ाइल को निम्न के रूप में .html फ़ाइल में जोड़ें -

<html>
   <head></head>
   <body>
      <script type="text/javascript" src="dev/main_bundle.js"></script>
   </body>
</html>

कमांड चलाएं -

npm run publish

आउटपुट की जांच करने के लिए, हम फ़ाइल को इसमें खोल सकते हैं -

http://localhost:8080/

जैसा कि ऊपर दिखाया गया है, हम कंसोल वैल्यू प्राप्त करते हैं। अब वेबपैक और बैबेल का उपयोग करके किसी एक फाइल को संकलित करने का प्रयास करते हैं।

हम एक ही फाइल में कई जेएस फाइलों को बंडल करने के लिए वेबपैक का उपयोग करेंगे। Babel का उपयोग es6 कोड को es5 पर संकलित करने के लिए किया जाएगा।

अब, हमारे पास ss / folder में 2 js फाइलें हैं - main.js और Person.js निम्नानुसार हैं -

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

हमने व्यक्ति वर्ग के विवरण का उपयोग करने के लिए निर्यात का उपयोग किया है।

main.js

import {Person} from './person'
var a = new Person("Siya", "Kapoor", "15", "Mumbai");
var persondet = a.fullname;
console.log(persondet);

Main.js में, हमने फ़ाइल पथ से व्यक्ति को आयात किया है।

Note- हमें person.js को शामिल नहीं करना है, लेकिन केवल फ़ाइल का नाम है। हमने व्यक्ति वर्ग की एक वस्तु बनाई है और ऊपर दिखाए अनुसार विवरणों को सांत्वना दी है।

Webpack गठबंधन करेगा person.js तथा main.js और में अपडेट करें dev/main_bundle.jsएक फ़ाइल के रूप में। कमांड चलाएंnpm run publish ब्राउज़र में आउटपुट की जाँच करने के लिए -