बेबेलजेएस - अवलोकन
BabelJSएक जावास्क्रिप्ट ट्रांसपिलर है जो पुराने मानक में नई सुविधाओं को स्थानांतरित करता है। इसके साथ, फीचर को पुराने और नए दोनों ब्राउज़रों पर चलाया जा सकता है, परेशानी मुक्त। एक ऑस्ट्रेलियाई डेवलपर, सेबस्टियन मैकेंजी ने बेबेलजेएस शुरू किया।
कोलाहल क्यों?
जावास्क्रिप्ट वह भाषा है जिसे ब्राउज़र समझता है। हम अपने अनुप्रयोगों को चलाने के लिए विभिन्न ब्राउज़रों का उपयोग करते हैं - क्रोम, फ़ायरफ़ॉक्स, इंटरनेट एक्सप्लोरर, माइक्रोसॉफ्ट एज, ओपेरा, यूसी ब्राउज़र आदि। ईसीएमए स्क्रिप्ट जावास्क्रिप्ट भाषा विनिर्देश है; ECMA स्क्रिप्ट 2015 ES6 स्थिर संस्करण है जो सभी नए और पुराने ब्राउज़रों में ठीक काम करता है।
ES5 के बाद, हमारे पास ES6, ES7 और ES8 हैं। ईएस 6 बहुत सारी नई विशेषताओं के साथ जारी किया गया है जो सभी ब्राउज़रों द्वारा पूरी तरह से समर्थित नहीं हैं। वही ES7, ES8 और ESNext (ECMA स्क्रिप्ट का अगला संस्करण) पर लागू होता है। यह अब अनिश्चित है जब सभी ब्राउज़रों के लिए जारी किए गए सभी ईएस संस्करणों के साथ संगत होना संभव होगा।
Incase हम अपने कोड को लिखने के लिए ES6 या ES7 या ES8 सुविधाओं का उपयोग करने की योजना बनाते हैं, क्योंकि यह नए परिवर्तनों के समर्थन की कमी के कारण कुछ पुराने ब्राउज़रों में टूट जाएगा। इसलिए, यदि हम अपने कोड में ECMA स्क्रिप्ट की नई विशेषताओं का उपयोग करना चाहते हैं और इसे उपलब्ध सभी संभव ब्राउज़रों पर चलाना चाहते हैं, तो हमें एक उपकरण की आवश्यकता है जो ES5 में हमारे अंतिम कोड को संकलित करेगा।
Babelऐसा ही होता है और इसे एक ट्रांसपॉइलर कहा जाता है जो ECMA स्क्रिप्ट संस्करण में कोड ट्रांसपाइल्स करता है जो हम चाहते हैं। इसमें प्रीसेट और प्लगइन्स जैसी विशेषताएं हैं, जो हमारे कोड को ट्रांसपाइल करने के लिए आवश्यक ईसीएमए संस्करण को कॉन्फ़िगर करते हैं। बबेल के साथ, डेवलपर्स जावास्क्रिप्ट में नई सुविधाओं का उपयोग करके अपना कोड लिख सकते हैं। उपयोगकर्ताओं को बेबल का उपयोग करके कोड ट्रांसपोंड मिल सकता है; कोड को बाद में किसी भी मुद्दे के बिना किसी भी ब्राउज़र में उपयोग किया जा सकता है।
The following table lists down the features available in ES6, ES7 and ES8 −
विशेषताएं | ECMA स्क्रिप्ट संस्करण |
---|---|
Let + Const | ES6 |
तीर कार्य | ES6 |
कक्षाएं | ES6 |
वादे | ES6 |
जेनरेटर | ES6 |
iterators | ES6 |
मॉड्यूल | ES6 |
Destructuring | ES6 |
खाका साहित्य | ES6 |
बढ़ी हुई वस्तु | ES6 |
डिफ़ॉल्ट, आराम और फैला हुआ गुण | ES6 |
Async - प्रतीक्षारत | ES7 |
घातांक संचालक | ES7 |
Array.prototype.includes () | ES7 |
स्ट्रिंग पैडिंग | ES8 |
बेबेलजेएस निम्नलिखित दो भागों का प्रबंधन करता है -
- transpiling
- polyfilling
बैबल-ट्रांसपिलर क्या है?
बैबल-ट्रांसपिलर आधुनिक जावास्क्रिप्ट के सिंटैक्स को एक रूप में परिवर्तित करता है, जिसे पुराने ब्राउज़रों द्वारा आसानी से समझा जा सकता है। उदाहरण के लिए, एरो फंक्शन, कॉन्स्ट, लेट क्लासेस को फंक्शन, वर्जन इत्यादि में बदल दिया जाएगा। यहाँ सिंटैक्स, यानी एरो फंक्शन दोनों मामलों में कार्यक्षमता को समान रखते हुए एक सामान्य फंक्शन में परिवर्तित हो जाता है।
बैबल-पॉलीफ़िल क्या है?
जावास्क्रिप्ट में नए फीचर्स जोड़े गए हैं जैसे वादे, नक्शे और शामिल हैं। सुविधाओं का उपयोग सरणी पर किया जा सकता है; वही, जब उपयोग किया जाता है और बेपेल का उपयोग किया जाता है तो परिवर्तित नहीं होगा। यदि नई सुविधा एक विधि या वस्तु है, तो हमें पुराने ब्राउज़रों को काम करने के लिए ट्रांसपिलिंग के साथ-साथ बैबल-पॉलीफिल का उपयोग करना होगा।
यहाँ जावास्क्रिप्ट में उपलब्ध ECMA स्क्रिप्ट सुविधाओं की सूची दी गई है, जिन्हें ट्रांसप्लड और पॉलीफ़िल्ड किया जा सकता है -
- Classes
- Decorators
- Const
- Modules
- Destructing
- डिफ़ॉल्ट पैरामीटर
- गणना की गई संपत्ति के नाम
- वस्तु विश्राम / प्रसार
- Async कार्य करता है
- तीर कार्य
- बाकी पैरामीटर
- Spread
- खाका साहित्य
ECMA Script features that can be polyfilled −
- Promises
- Map
- Set
- Symbol
- Weakmap
- Weakset
- includess
- Array.from, Array.of, Array # खोजें, Array.buffer, Array # findIndex
- Object.assign,Object.entries,Object.values
बबलजेएस की विशेषताएं
इस खंड में, हम BabelJS की विभिन्न विशेषताओं के बारे में जानेंगे। बबलजेएस की सबसे महत्वपूर्ण मुख्य विशेषताएं निम्नलिखित हैं -
कोलाहल-प्लगइन्स
प्लग और प्रीसेट्स कोड को ट्रांसपाइल करने के लिए बाबेल के लिए कॉन्फ़िगर विवरण हैं। बैबेल कई प्लगइन्स का समर्थन करता है, जिसका उपयोग व्यक्तिगत रूप से किया जा सकता है, अगर हम उस वातावरण को जानते हैं जिसमें कोड निष्पादित होगा।
कोलाहल-प्रीसेट
बैबेल प्रीसेट प्लगइन्स का एक सेट है, अर्थात, बैबल-ट्रांसपॉइलर के लिए कॉन्फ़िगर विवरण जो एक विशिष्ट मोड में बैबल को ट्रांसपाइल करने का निर्देश देता है। हमें प्रीसेट का उपयोग करने की आवश्यकता है, जिसमें पर्यावरण है जिसमें हम चाहते हैं कि कोड परिवर्तित किया जाए। उदाहरण के लिए, es2015 प्रीसेट कोड को es5 में बदल देगा ।
कोलाहल-Polyfills
विधियों और वस्तुओं जैसी कुछ विशेषताएं हैं, जिन्हें स्थानांतरित नहीं किया जा सकता है। ऐसे उदाहरणों में, हम किसी भी ब्राउज़र में सुविधाओं के उपयोग को सुविधाजनक बनाने के लिए बैबल-पॉलीफिल का उपयोग कर सकते हैं। आइए हम वादों के उदाहरण पर विचार करें; पुराने ब्राउज़र में काम करने की सुविधा के लिए, हमें पॉलीफ़िल का उपयोग करने की आवश्यकता है।
कोलाहल-Polyfills
Babel-cli कमांड के एक समूह के साथ आता है जहाँ कोड को कमांड लाइन पर आसानी से संकलित किया जा सकता है। इसमें प्लगइन्स और प्रीसेट जैसे फीचर्स भी इस्तेमाल किए जा सकते हैं और कमांड के साथ कोड को एक बार में ट्रांसपाइल करना आसान है।
BabelJS का उपयोग करने के लाभ
इस भाग में, हम BabelJS के उपयोग से जुड़े विभिन्न लाभों के बारे में जानेंगे -
BabelJS जावास्क्रिप्ट में सभी नव जोड़ी सुविधाओं के लिए पिछड़े संगतता प्रदान करता है और किसी भी ब्राउज़र में उपयोग किया जा सकता है।
BabelJS में जावास्क्रिप्ट के अगले आगामी संस्करण को लेने की क्षमता है - ES6, ES7, ESNext, आदि।
BabelJS का उपयोग गल्प, वेबपैक, प्रवाह, प्रतिक्रिया, टाइपस्क्रिप्ट आदि के साथ किया जा सकता है, जो इसे बहुत शक्तिशाली बनाता है और इसका उपयोग बड़े प्रोजेक्ट के साथ किया जा सकता है जो डेवलपर के जीवन को आसान बनाता है।
BabelJS JSX सिंटैक्स पर प्रतिक्रिया के साथ भी काम करता है और इसे JSX रूप में संकलित किया जा सकता है।
BabelJS में प्लगइन्स, पॉलीफ़िल्स, बैबल-क्ली के लिए समर्थन है जो बड़ी परियोजनाओं के साथ काम करना आसान बनाता है।
BabelJS का उपयोग करने के नुकसान
इस भाग में, हम BabelJS का उपयोग करने के विभिन्न नुकसानों के बारे में जानेंगे -
BabelJS कोड ट्रांसप्लीन करते समय वाक्यविन्यास को बदलता है जो उत्पादन पर जारी होने पर कोड को समझना मुश्किल बनाता है।
मूल कोड की तुलना में कोड ट्रांसप्लड आकार में अधिक है।
सभी ईएस 6/7/8 या आगामी नई सुविधाओं को ट्रांसप्लड नहीं किया जा सकता है और हमें पॉलीफिल का उपयोग करना होगा ताकि यह पुराने ब्राउज़रों के लिए काम करे।
यहाँ babeljs की आधिकारिक साइट है https://babeljs.io/।