बैबेलजस - बैबेल पॉलीफिल

बैबल पॉलीफ़िल सुविधाओं के लिए वेब ब्राउज़र को समर्थन जोड़ता है, जो उपलब्ध नहीं हैं। बैबेल ने हाल के एक्मा वर्जन के कोड को उसी से संकलित किया है, जिसे हम चाहते हैं। यह प्रीसेट के अनुसार सिंटैक्स को बदलता है, लेकिन उपयोग की गई वस्तुओं या विधियों के लिए कुछ भी नहीं कर सकता है। हमें पिछड़े संगतता के लिए उन सुविधाओं के लिए पॉलीफिल का उपयोग करना होगा।

सुविधाएँ जो पॉलीफ़िल की जा सकती हैं

पुराने ब्राउज़र में उपयोग किए जाने पर पॉलीफ़िल समर्थन की आवश्यकता वाले फ़ीचर की सूची निम्नलिखित है -

  • Promises
  • Map
  • Set
  • Symbol
  • Weakmap
  • Weakset
  • Array.from, Array.includes, Array.of, Array # ढूंढें, Array.buffer, Array # findIndex
  • Object.assign, Object.entries, Object.values

हम प्रोजेक्ट सेटअप बनाएंगे और बेबल पॉलीफिल का काम भी देखेंगे।

आदेश

npm init

अब हम babel के लिए आवश्यक संकुल संस्थापित करेंगे।

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

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

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

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

यहाँ अंतिम पैकेज है। Json -

हम प्रीसेट में es2015 भी जोड़ देंगे, क्योंकि हम es5 को कोड संकलित करना चाहते हैं।

.babelrc for babel 6

.babelrc for babel 7

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

हम एक लाइट-सर्व स्थापित करेंगे ताकि हम ब्राउज़र में अपने कोड का परीक्षण कर सकें -

npm install --save-dev lite-server

पैकेज में हमारे कोड को संकलित करने के लिए हमें babel कमांड जोड़ें।

हमने बिल्ड कमांड भी जोड़ा है जो लाइट-सर्वर को कॉल करता है।

बैबल-कोर पैकेज के साथ बैबल-पॉलीफिल स्थापित हो जाता है। बाबेल-पॉलीफिल नोड मॉड्यूल में उपलब्ध होगा जैसा कि नीचे दिखाया गया है -

हम वादों पर आगे काम करेंगे और इसके साथ ही बेबल-पॉलीफिल का उपयोग करेंगे।

ईएस 6 - वादे

let timingpromise = new Promise((resolve, reject) => {
   setTimeout(function() {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then((msg) => {
   console.log("%c"+msg, "font-size:25px;color:red;");
});

आदेश

npx babel promise.js --out-file promise_es5.js

बैबलजेएस - ईएस 5

"use strict";

var timingpromise = new Promise(function (resolve, reject) {
   setTimeout(function () {
      resolve("Promise is resolved!");
   }, 1000);
});

timingpromise.then(function (msg) {
   console.log("%c"+msg, "font-size:25px;color:red;");
});

संकलन को कुछ भी बदलने की आवश्यकता नहीं है। वादे के लिए कोड ट्रांसप्लड किया गया है जैसा कि यह है। लेकिन जो ब्राउज़र वादों का समर्थन नहीं करते हैं वे एक त्रुटि को फेंक देंगे भले ही हमने कोड को es5 में संकलित किया हो।

इस समस्या को हल करने के लिए, हमें अंतिम es5 संकलित कोड के साथ पॉलीफिल को जोड़ना होगा। कोड को ब्राउज़र में चलाने के लिए, हम नोड मॉड्यूल से बैबेल-पॉलीफ़िल फ़ाइल लेंगे और इसे .html फ़ाइल में जोड़ेंगे जहाँ हम नीचे दिखाए गए वादों का उपयोग करना चाहते हैं -

index.html

<html>
   <head>
   </head>
   <body>
      <h1>Babel Polyfill Testing</h1>
      <script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>
      <script type="text/javascript" src="promise_es5.js"></script>
   </body>
</html>

उत्पादन

Index.html फ़ाइल में, हमने polyfill.min.js फ़ाइल का उपयोग किया है node_modules इसके बाद वादा_से 5.js -

<script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>

<script type="text/javascript" src="promise_es5.js"></script>

Note - पॉलीफ़िल फ़ाइल का उपयोग मुख्य जावास्क्रिप्ट कॉल से पहले शुरू में किया जाना चाहिए।

स्ट्रिंग पैडिंग

स्ट्रिंग पैडिंग निर्दिष्ट लंबाई के अनुसार बाईं ओर से एक और स्ट्रिंग जोड़ता है। स्ट्रिंग पैडिंग के लिए वाक्य रचना नीचे दिखाया गया है -

वाक्य - विन्यास

str.padStart(length, string);
str.padEnd(length, string);

उदाहरण

const str = 'abc';

console.log(str.padStart(8, '_'));
console.log(str.padEnd(8, '_'));

उत्पादन

_____abc
abc_____

बैबल - ईएस 5

npx babel strpad.js --out-file strpad_es5.js

आदेश

'use strict';

var str = 'abc';

console.log(str.padStart(8, '_'));
console.log(str.padEnd(8, '_'));

जेएस को नीचे दिखाए अनुसार बैबल-पॉलीफिल के साथ प्रयोग किया जाना है -

test.html

<!DOCTYPE html>
<html>
   <head>
      <title>BabelJs Testing </title>
   </head>
   <body>
      <script src="node_modules/babel-polyfill/dist/polyfill.min.js" type="text/javascript"></script>
      <script type="text/javascript" src="strpad_es5.js"></script>
   </body>
</html>

नक्शा, सेट, कमजोर, कमजोर नक्शा

इस खंड में, हम इस बारे में जानेंगेMap, Set, WeakSet, WeakMap.

  • Map कुंजी / मान युग्म के साथ एक वस्तु है।

  • Set एक वस्तु भी है, लेकिन अद्वितीय मूल्यों के साथ।

  • WeakMap and WeakSet iare भी कुंजी / मान जोड़े के साथ वस्तुओं।

मैप, सेट, वीकैप और वीकसेट, ES6 में जोड़े गए नए फीचर्स हैं। पुराने ब्राउज़रों में इसका उपयोग करने के लिए, हमें पॉलीफ़िल का उपयोग करने की आवश्यकता है। हम एक उदाहरण पर काम करेंगे और कोड संकलित करने के लिए पॉलीफिल का उपयोग करेंगे।

उदाहरण

let m = new Map(); //map example
m.set("0","A");
m.set("1","B");
console.log(m);

let set = new Set(); //set example
set.add('A');
set.add('B');
set.add('A');
set.add('B');
console.log(set);

let ws = new WeakSet(); //weakset example
let x = {};
let y = {};
ws.add(x);
console.log(ws.has(x));
console.log(ws.has(y));

let wm = new WeakMap(); //weakmap example
let a = {};
wm.set(a, "hello");
console.log(wm.get(a));

उत्पादन

Map(2) {"0" => "A", "1" => "B"}
Set(2) {"A", "B"}
true
false
hello

आदेश

npx babel set.js --out-file set_es5.js

कोलाहल-ES5

"use strict";

var m = new Map(); //map example
m.set("0", "A");
m.set("1", "B");
console.log(m);

var set = new Set(); //set example
set.add('A');
set.add('B');
set.add('A');
set.add('B');
console.log(set);

var ws = new WeakSet(); //weakset example
var x = {};
var y = {};
ws.add(x);
console.log(ws.has(x));
console.log(ws.has(y));

var wm = new WeakMap(); //weakmap example
var a = {};
wm.set(a, "hello");
console.log(wm.get(a));

जेएस को नीचे दिखाए अनुसार बैबल-पॉलीफिल के साथ प्रयोग किया जाना है -

test.html

<!DOCTYPE html>
<html>
   <head>
      <title>BabelJs Testing</title>
   </head>
   <body>
      <script src="node_modules/babel-polyfill/dist/polyfill.min.js" type="text/javascript"></script>
      <script type="text/javascript" src="set_es5.js"></script>
   </body>
</html>

उत्पादन

ऐरे तरीके

कई गुणों और विधियों का उपयोग सरणी पर किया जा सकता है; उदाहरण के लिए, array.from, array.includes, आदि।

आइए इसे बेहतर समझने के लिए हम निम्नलिखित उदाहरण पर काम करते हैं।

उदाहरण

arraymethods.js

var arrNum = [1, 2, 3];

console.log(arrNum.includes(2));
console.log(Array.from([3, 4, 5], x => x + x));

Output

true
[6, 8, 10]

आदेश

npx babel arraymethods.js --out-file arraymethods_es5.js

कोलाहल-es5

"use strict";

var arrNum = [1, 2, 3];

console.log(arrNum.includes(2));
console.log(Array.from([3, 4, 5], function (x) {
return x + x;
}));

सरणी पर उपयोग की गई विधियों को मुद्रित किया जाता है जैसे वे हैं। पुराने ब्राउज़रों पर काम करने के लिए, हमें शुरू में पॉलीफ़िल फ़ाइल जोड़ने की आवश्यकता है, जैसा कि नीचे दिखाया गया है -

index.html

<html>
   <head></head>
   <body>
      <h1>Babel Polyfill Testing</h1>
      <script type="text/javascript" src="node_modules/babel-polyfill/dist/polyfill.min.js"></script>
      <script type="text/javascript" src="arraymethods_es5.js"></script>
   </body>
</html>

उत्पादन