बेबेलजेएस - बाबेल सीएलआई
BabelJS एक अंतर्निहित कमांड लाइन इंटरफेस के साथ आता है, जिसमें जावास्क्रिप्ट कोड आसानी से संबंधित ECMA स्क्रिप्ट को आसानी से कमांड का उपयोग करके संकलित किया जा सकता है। हम इस अध्याय में इन कमांड के उपयोग पर चर्चा करेंगे।
पहले, हम अपने प्रोजेक्ट के लिए babel-cli इंस्टॉल करेंगे। हम कोड को संकलित करने के लिए babeljs का उपयोग करेंगे।
अपने प्रोजेक्ट के लिए बेबल-क्ली के साथ खेलने के लिए एक फ़ोल्डर बनाएँ।
आदेश
npm init
प्रदर्शन
उपरोक्त प्रोजेक्ट के लिए पैकेज.जॉन -
आइए हम बेबल-क्ली स्थापित करने के लिए कमांड चलाते हैं।
बाबेल के लिए पैकेज ६
npm install --save-dev babel-cli
बाबेल के लिए पैकेज 7
npm install --save-dev @babel/cli
प्रदर्शन
हमने babel-cli स्थापित किया है और यहां अपडेट किया गया पैकेज है। Json -
इसके अलावा, हमें बैबेल-प्रीसेट और बैबेल-कोर को स्थापित करने की आवश्यकता है। अब इंस्टॉलेशन के लिए कमांड देखते हैं।
बाबेल के लिए पैकेज ६
npm install --save-dev babel-preset-env
npm install --save-dev babel-core
बाबेल के लिए पैकेज 7
npm install --save-dev @babel/core
npm install --save-dev @babel/preset-env
यहाँ उपरोक्त संकुल के लिए अद्यतन package.json है -
चूंकि हमें जावास्क्रिप्ट कोड को संकलित करने की आवश्यकता है जिसे हम पिछड़े संगतता के लिए लिखने जा रहे हैं, हम इसे ईसीएमए स्क्रिप्ट 5 में संकलित करेंगे। इसके लिए, हमें बैबेल को प्रीसेट देखने के लिए निर्देश देने की आवश्यकता है, अर्थात, एसवाई संस्करण जिसमें संकलन होगा किया हुआ। हमें एक बनाने की जरूरत है.babelrc> नीचे दिखाए गए के रूप में बनाई गई हमारी परियोजना के रूट फ़ोल्डर में फ़ाइल।
इसमें निम्नलिखित प्रीसेट विवरण के साथ एक json ऑब्जेक्ट है -
{ "presets": ["env"] }
बाबेल 7 के लिए .babelrc निम्नानुसार है -
{
"presets":["@babel/env"]
}
हमने प्रोजेक्ट के लिए बेबल लोकल इंस्टॉल किए हैं। हमारी परियोजना में बैबल का उपयोग करने के लिए, हमें पैकेज में समान निर्दिष्ट करना होगा।
जेएस फाइलें संकलित करें
अब हम अपनी जावास्क्रिप्ट फ़ाइलों को संकलित करने के लिए तैयार हैं। अपने प्रोजेक्ट में एक फ़ोल्डर बनाएँ; इस फ़ोल्डर में, main.js नामक एक फाइल बनाएं और नीचे दिखाए अनुसार एक es6 जावास्क्रिप्ट कोड लिखें -
आदेश
npx babel src/main.js
उत्पादन
उपरोक्त मामले में, main.js से कोड es5 संस्करण में टर्मिनल में प्रदर्शित होता है। जैसा कि ऊपर दिखाया गया है es6 से एरो फंक्शन es5 में बदल जाता है। टर्मिनल में संकलित कोड प्रदर्शित करने के बजाय, हम इसे नीचे दिखाए गए अनुसार एक अलग फ़ाइल में संग्रहीत करेंगे।
हमने अपनी परियोजना में एक फ़ोल्डर बनाया है, जिसमें कहा गया है कि हम चाहते हैं कि संकलित फ़ाइलें संग्रहीत की जाएं। निम्नलिखित वह कमांड है जो हम जहां चाहें आउटपुट को संकलित और संग्रहीत करेंगे।
आदेश
npx babel src/main.js --out-file out/main_out.js
उत्पादन
कमांड - आउट-फाइल में विकल्प हमें आउटपुट को हमारी पसंद के फ़ाइल स्थान में संग्रहीत करने में मदद करता है।
हम चाहते हैं कि फ़ाइल को हर बार अपडेट किया जाए ताकि हम मुख्य फ़ाइल जोड़ में बदलाव कर सकें --watch या -w नीचे दिखाए अनुसार कमांड का विकल्प।
आदेश
npx babel src/main.js --watch --out-file out/main_out.js
उत्पादन
आप मुख्य फ़ाइल में परिवर्तन कर सकते हैं; यह परिवर्तन संकलित फ़ाइल में प्रतिबिंबित होगा।
उपरोक्त मामले में, हमने लॉग संदेश और बदल दिया --watch विकल्प किसी भी परिवर्तन के लिए जाँच करता रहता है और उसी परिवर्तन को संकलित फ़ाइल में जोड़ा जाता है।
संकलित फ़ाइल
हमारे पिछले अनुभागों में, हमने सीखा कि व्यक्तिगत फ़ाइलों को कैसे संकलित किया जाए। अब, हम एक निर्देशिका संकलित करेंगे और संकलित फ़ाइलों को दूसरी निर्देशिका में संग्रहीत करेंगे।
Src फ़ोल्डर में, हम एक और js फाइल बनाएंगे, जिसे कहा जाता है main1.js। वर्तमान में, src फ़ोल्डर में 2 जावास्क्रिप्ट फाइलें हैंmain.js तथा main1.js।
निम्नलिखित फाइल में कोड है -
main.js
var arrowfunction = () => {
console.log("Added changes to the log message");
}
main1.js
var handler = () => {
console.log("Added one more file");
}
निम्नलिखित आदेश से कोड संकलित करेगा srcफ़ोल्डर और इसे बाहर / फ़ोल्डर में संग्रहीत करें। हमने सभी फाइलों को हटा दिया हैout/फ़ोल्डर और इसे खाली रखा। हम कमांड को रन करेंगे और आउट / फोल्डर में आउटपुट चेक करेंगे।
आदेश
npx babel src --out-dir out
हमें आउट फ़ोल्डर में 2 फाइलें मिलीं- main.js और main1.js
main.js
"use strict";
var arrowfunction = function arrowfunction() {
console.log("Added changes to the log message");
};
main1.js
"use strict";
var handler = function handler() {
console.log("Added one more file");
};
इसके बाद, हम नीचे दिए गए कमांड को बाबेलज का उपयोग करके दोनों फाइलों को एक ही फाइल में संकलित करने के लिए निष्पादित करेंगे।
आदेश
npx babel src --out-file out/all.js
उत्पादन
"use strict";
var arrowfunction = function arrowfunction() {
console.log("Added changes to the log message");
};
"use strict";
var handler = function handler() {
console.log("Added one more file");
};
यदि हम कुछ फ़ाइलों को संकलित होने से अनदेखा करना चाहते हैं, तो हम नीचे दिखाए गए अनुसार विकल्प --ignore का उपयोग कर सकते हैं।
आदेश
npx babel src --out-file out/all.js --ignore src/main1.js
उत्पादन
all.js
"use strict";
var arrowfunction = function arrowfunction() {
console.log("Added changes to the log message");
};
हम फ़ाइल संकलन के दौरान उपयोग किए जाने वाले प्लगइन्स विकल्पों का उपयोग कर सकते हैं। प्लगइन्स का उपयोग करने के लिए, हमें इसे नीचे दिखाए अनुसार इंस्टॉल करना होगा।
आदेश
npm install --save-dev babel-plugin-transform-exponentiation-operator
expo.js
let sqr = 9 ** 2;
console.log(sqr);
आदेश
npx babel expo.js --out-file expo_compiled.js --plugins=babel-plugin-transform-exponentiation-operator
उत्पादन
"use strict";
var sqr = Math.pow(9, 2);
console.log(sqr);
हम कमांड में प्रीसेट का भी उपयोग कर सकते हैं जैसा कि नीचे दिखाया गया है।
आदेश
npx babel src/main.js --out-file main_es5.js --presets=es2015
उपरोक्त मामले का परीक्षण करने के लिए, हमने .babelrc से प्रीसेट विकल्प हटा दिया है।
main.js
var arrowfunction = () => {
console.log("Added changes to the log message");
}
main_es5.js
"use strict";
var arrowfunction = function arrowfunction() {
console.log("Added changes to the log message");
};
हम कमांड लाइन से .babelrc को भी अनदेखा कर सकते हैं -
npx babel --no-babelrc src/main.js --out-file main_es5.js --presets=es2015
उपरोक्त मामले का परीक्षण करने के लिए, हमने प्रीसेट को वापस .babelrc में जोड़ दिया है और उसी को अनदेखा कर दिया जाएगा - क्योंकि-babelrc जो हमने कमांड में जोड़ा है। Main_es5.js फ़ाइल विवरण निम्नानुसार हैं -
main_es5.js
"use strict";
var arrowfunction = function arrowfunction() {
console.log("Added changes to the log message");
};