बेबेलजेएस - बैबेल प्रीसेट्स
बैबेल प्रीसेट, बफ़ेल-ट्रांसपिलर के लिए कॉन्फ़िगर विवरण हैं जो इसे निर्दिष्ट मोड में ट्रांसपाइल करने के लिए कह रहा है। यहाँ हम इस अध्याय में चर्चा करने वाले कुछ सबसे लोकप्रिय नुस्खे हैं -
- ES2015
- Env
- React
हमें उन प्रीसेट्स का उपयोग करने की आवश्यकता है जिनके पास वातावरण है जिसमें हम चाहते हैं कि कोड परिवर्तित किया जाए। उदाहरण के लिए, es2015 प्रीसेट कोड को es5 में बदल देगा । मान env के साथ पूर्व निर्धारित भी es5 में बदल जाएगा । इसमें अतिरिक्त सुविधा भी है, अर्थात, विकल्प। यदि आप चाहते हैं कि फीचर को ब्राउज़रों के हाल के संस्करणों पर समर्थित किया जाए, तो बेबल केवल उन ब्राउज़रों पर सुविधाओं का समर्थन नहीं होने पर कोड को बदल देगा। प्रीसेट प्रतिक्रिया के साथ , बैबेल कोड को ट्रांसपाइल करेगा जब प्रतिक्रिया करनी होगी।
प्रीसेट्स के साथ काम करने के लिए, हमें अपने प्रोजेक्ट रूट फ़ोल्डर में .babelrc फ़ाइल बनाने की आवश्यकता है। काम दिखाने के लिए, हम नीचे दिखाए गए अनुसार एक प्रोजेक्ट सेटअप बनाएंगे।
आदेश
npm init
हमें बबैल क्ली, बैबेल कोर इत्यादि के साथ आवश्यक बाबेल प्रीसेट स्थापित करना होगा।
बैबल 6 पैकेज
npm install babel-cli babel-core babel-preset-es2015 --save-dev
बैबल 7 पैकेज
npm install @babel/cli @babel/core @babel/preset-env --save-dev
Note - babel-preset-es2015 को बाबेल 7 पर निकाला जाता है।
es2015 or @babel/env
प्रोजेक्ट के मूल में .babelrc फ़ाइल बनाएँ (6 babel) -
.Babelrc में, presets es2015 है। यह बैबल कंपाइलर का संकेत है कि हम कोड को es2015 में बदलना चाहते हैं।
बाबेल 7 के लिए, हमें निम्नानुसार प्रीसेट का उपयोग करना होगा -
{
"presets":["@babel/env"]
}
यहाँ स्थापना के बाद package.json है -
चूँकि हमने स्थानीय स्तर पर बाबेल स्थापित किया है, हमने संकुल खंड में स्क्रिप्ट अनुभाग में बाबेल कमांड जोड़ा है।
प्रीसेट es2015 का उपयोग करके ट्रांसप्लिंग के लिए जांच करने के लिए एक सरल उदाहरण पर काम करते हैं।
उदाहरण
main.js
let arrow = () => {
return "this is es6 arrow function";
}
जैसा कि नीचे दिखाया गया है es5 को ट्रांसप्लड किया गया।
आदेश
npx babel main.js --out-file main_es5.js
main_es5.js
"use strict";
var arrow = function arrow() {
return "this is es6 arrow function";
};
env
Env पूर्व निर्धारित का उपयोग करके, आप पर्यावरण को निर्दिष्ट कर सकते हैं जिसे आपको अंतिम कोड ट्रांसप्लड किया जाना है।
हम ऊपर बनाए गए समान प्रोजेक्ट सेटअप का उपयोग करने जा रहे हैं और प्रीसेट को es2015 से बदलकर नीचे दिखाए गए रूप में बदल सकते हैं।
इसके अलावा, हमें बैबेल-प्रीसेट-एनव को स्थापित करने की आवश्यकता है। हम उसी को स्थापित करने के लिए नीचे दिए गए कमांड को निष्पादित करेंगे।
आदेश
npm install babel-preset-env --save-dev
हम main.js को फिर से संकलित करेंगे और आउटपुट देखेंगे।
main.js
let arrow = () => {
return "this is es6 arrow function";
}
आदेश
npx babel main.js --out-file main_env.js
main_env.js
"use strict";
var arrow = function arrow() {
return "this is es6 arrow function";
};
हमने देखा है कि ट्रांसपोंड कोड es5 है। हम यह जानते हैं कि जिस वातावरण में हमारा कोड निष्पादित होने वाला है, हम इसे निर्दिष्ट करने के लिए इस पूर्व निर्धारित का उपयोग कर सकते हैं। उदाहरण के लिए, यदि हम ब्राउज़रों को क्रोम और फ़ायरफ़ॉक्स के लिए अंतिम 1 संस्करण के रूप में निर्दिष्ट करते हैं जैसा कि नीचे दिखाया गया है।
आदेश
npx babel main.js --out-file main_env.js
main_env.js
"use strict";
let arrow = () => {
return "this is es6 arrow function";
};
हमें अब एरो फ़ंक्शन सिंटैक्स मिल रहा है जैसा कि यह है। इसे ES5 सिंटैक्स में ट्रांसप्लड नहीं किया जाता है। इसका कारण यह है कि पर्यावरण जिसे हम अपने कोड का समर्थन करना चाहते हैं, पहले से ही तीर फ़ंक्शन के लिए समर्थन है।
बैबेल-प्रीसेट-एनवी का उपयोग करके पर्यावरण के आधार पर कोड को संकलित करने का ध्यान रखता है। हम नीचे दिखाए गए अनुसार नोडज वातावरण के आधार पर संकलन को भी लक्षित कर सकते हैं
कोड का अंतिम संकलन नीचे दिखाया गया है।
आदेश
npx babel main.js --out-file main_env.js
main_env.js
"use strict";
let arrow = () => {
return "this is es6 arrow function";
};
Babel नोडज के वर्तमान संस्करण के अनुसार कोड संकलित करता है।
प्रतिक्रिया पूर्व निर्धारित
जब हम Reactjs का उपयोग कर रहे हैं तो हम अभिकर्मक प्रीसेट का उपयोग कर सकते हैं। हम एक साधारण उदाहरण पर काम करेंगे और आउटपुट देखने के लिए प्रीसेट प्रतिक्रिया का उपयोग करेंगे।
पूर्व निर्धारित का उपयोग करने के लिए, हमें निम्नानुसार बेबल-प्रीसेट-प्रतिक्रिया (बैबल 6) स्थापित करने की आवश्यकता है -
npm install --save-dev babel-preset-react
बाबेल 7 के लिए, यह इस प्रकार है -
npm install --save-dev @babel/preset-react
बेबेल 6 के लिए .babelrc के परिवर्तन इस प्रकार हैं -
बबैल के लिए el
{
"presets": ["@babel/preset-react"]
}
main.js
<h1>Hello, world!</h1>
आदेश
npx babel main.js --out-file main_env.js
main_env.js
React.createElement(
"h1",
null,
"Hello, world!"
);
Main.js से कोड प्रीसेट के साथ सिंटैक्स रिएक्टज में बदल जाता है: प्रतिक्रिया।