ईएस 8 - नई सुविधाएँ

यह अध्याय ईएस 8 में नई सुविधाओं पर केंद्रित है।

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

ES8 एक स्ट्रिंग पैडिंग के लिए दो स्ट्रिंग हैंडलिंग कार्यों का परिचय देता है। इन फ़ंक्शन का उपयोग स्ट्रिंग मान के आरंभ और अंत में स्थान या किसी भी वांछित वर्ण को जोड़ने के लिए किया जा सकता है।

स्ट्रिंग। padStart ()

यह फ़ंक्शन प्रारंभ से बार-बार दिए गए इनपुट स्ट्रिंग के साथ वर्तमान स्ट्रिंग को पैड करता है, जब तक कि वर्तमान स्ट्रिंग दी गई लंबाई तक नहीं पहुंच जाती। पैडस्टार्ट () फ़ंक्शन का सिंटैक्स नीचे दिया गया है -

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

string_value.padStart(targetLength [, padString])

पैडस्टार्ट () फ़ंक्शन दो मापदंडों को स्वीकार करता है जो निम्नानुसार हैं -

  • targetLength- एक संख्यात्मक मान जो पैडिंग के बाद स्ट्रिंग की लक्ष्य लंबाई का प्रतिनिधित्व करता है। यदि इस पैरामीटर का मान स्ट्रिंग की मौजूदा लंबाई से कम या उसके बराबर है, तो स्ट्रिंग मान वापस आ जाता है।

  • padString- यह एक वैकल्पिक पैरामीटर है। यह पैरामीटर उन वर्णों को निर्दिष्ट करता है जिनका उपयोग स्ट्रिंग को पैड करने के लिए किया जाना चाहिए। यदि कोई मान इस पैरामीटर के लिए पारित नहीं किया जाता है, तो स्ट्रिंग मान रिक्त स्थान के साथ गद्देदार होता है।

उदाहरण

निम्न उदाहरण एक स्ट्रिंग चर, product_cost की घोषणा करता है। चर बाईं ओर से शून्य से गद्देदार होगा जब तक कि स्ट्रिंग की कुल लंबाई सात नहीं हो जाती। उदाहरण पैडस्टार्ट () फ़ंक्शन के व्यवहार को भी दिखाता है, अगर कोई मान दूसरे पैरामीटर पर नहीं जाता है।

<script>

   //pad the String with 0
   let product_cost = '1699'.padStart(7,0)
   console.log(product_cost)
   console.log(product_cost.length)

   //pad the String with blank spaces
   let product_cost1 = '1699'.padStart(7)
   console.log(product_cost1)
   console.log(product_cost1.length)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

0001699
7
1699
7

String.padEnd ()

यह फ़ंक्शन दी गई इनपुट स्ट्रिंग के साथ वर्तमान स्ट्रिंग को अंत से बार-बार पैड करता है, जब तक कि वर्तमान स्ट्रिंग निर्दिष्ट लंबाई तक नहीं पहुंच जाती।

पैडएंड () फ़ंक्शन का सिंटैक्स नीचे दिया गया है -

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

string_value.padEnd(targetLength [, padString])

पैडएंड () फ़ंक्शन दो मापदंडों को स्वीकार करता है -

  • targetLength- एक संख्यात्मक मान जो पैडिंग के बाद स्ट्रिंग की लक्ष्य लंबाई का प्रतिनिधित्व करता है। यदि इस पैरामीटर का मान स्ट्रिंग की मौजूदा लंबाई से कम या उसके बराबर है, तो स्ट्रिंग मान वापस आ जाता है।

  • padString- यह एक वैकल्पिक पैरामीटर है। यह पैरामीटर उन वर्णों को निर्दिष्ट करता है जिनका उपयोग स्ट्रिंग को पैड करने के लिए किया जाना चाहिए। यदि कोई मान इस पैरामीटर के लिए पारित नहीं किया जाता है, तो स्ट्रिंग मान रिक्त स्थान के साथ गद्देदार होता है।

उदाहरण

निम्न उदाहरण एक स्ट्रिंग चर, product_cost की घोषणा करता है। चर ठीक से सात है जब तक चर सही से शून्य के साथ गद्देदार किया जाएगा। उदाहरण पैडस्टार्ट () फ़ंक्शन के व्यवहार को भी दिखाता है, अगर कोई मान दूसरे पैरामीटर पर नहीं जाता है।

<script>

   //pad the string with x
   let product_cost = '1699'.padEnd(7,'x')
   console.log(product_cost)
   console.log(product_cost.length)
   
   //pad the string with spaces
   let product_cost1 = '1699'.padEnd(7)
   console.log(product_cost1)
   console.log(product_cost1.length)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

1699xxx
7
1699
7

ट्रेलिंग कॉमस

एक सूची में अंतिम आइटम के बाद एक अल्पविराम अल्पविराम बस एक अल्पविराम है। ट्रेलिंग कॉमा को अंतिम कॉमा के रूप में भी जाना जाता है।

Commas और Array अनुगामी

Array.prototype.forEach लूप का उपयोग करते समय सरणियों में ट्रेलिंग कॉमा को छोड़ दिया जाता है।

उदाहरण

निम्न उदाहरण फॉरेक्स लूप का उपयोग करके अल्पविराम के साथ एक सरणी को पुनरावृत्त करता है।

<script>

   let marks = [100,90,80,,]
   console.log(marks.length)
   console.log(marks)
   marks.forEach(function(e){ //ignores empty value in array
      console.log(e)
   })
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

4
[100, 90, 80, empty]
100
90
80

ट्रेलिंग कॉमा और फ़ंक्शन कॉल

एक समारोह को परिभाषित करने या लागू करने के दौरान, अनुगामी तर्कों को जावास्क्रिप्ट रनटाइम इंजन द्वारा नजरअंदाज कर दिया जाता है। हालाँकि, दो अपवाद हैं -

  • फ़ंक्शन परिभाषाएँ या मंगलाचरण जिसमें केवल एक अल्पविराम होता है, सिंटेक्सएरर में परिणाम होगा। उदाहरण के लिए, निम्नलिखित स्निपेट एक त्रुटि फेंक देगा -

function test(,){} // SyntaxError: missing formal parameter
(,)=>{}; //SyntaxError: expected expression, got ','
test(,) //SyntaxError: expected expression, got ','
  • बाकी मापदंडों के साथ ट्रेलिंग कॉमा का उपयोग नहीं किया जा सकता है।

function test(...arg1,){} // SyntaxError: parameter after rest parameter
(...arg1,)=>{} // SyntaxError: expected closing parenthesis, got ','

उदाहरण

निम्नलिखित उदाहरण तर्क सूची में अल्पविराम के साथ एक फ़ंक्शन की घोषणा करता है।

<script>

   function sumOfMarks(marks,){ // trailing commas are ignored
      let sum=0;
      marks.forEach(function(e){
         sum+=e;
      })
      return sum;
   }

   console.log(sumOfMarks([10,20,30]))
   console.log(sumOfMarks([1,2,3],))// trailing comma is ignored
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार है -

60
6

ऑब्जेक्ट: प्रविष्टियाँ () और मान ()

ES8 बिल्ट-इन ऑब्जेक्ट प्रकार के लिए निम्नलिखित नए तरीके पेश करता है -

  • Object.entries - Object.entries () विधि का उपयोग किसी ऑब्जेक्ट के सभी गुणों को एक्सेस करने के लिए किया जा सकता है।

  • Object.values() - Object.values ​​() विधि का उपयोग किसी ऑब्जेक्ट के सभी गुणों के मूल्यों तक पहुंचने के लिए किया जा सकता है।

  • Object.getOwnPropertyDescriptors()- यह विधि किसी वस्तु के सभी गुण वर्णनकर्ता के पास एक वस्तु लौटाती है। यदि ऑब्जेक्ट में कोई गुण नहीं है, तो खाली ऑब्जेक्ट लौटाया जा सकता है।

उदाहरण

<script>
   const student ={
      firstName:'Kannan',
      lastName:'Sudhakaran'
   }
   console.log(Object.entries(student))
   console.log(Object.values(student))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

[
["firstName", "Kannan"],
["lastName", "Sudhakaran"],
]
["Kannan", "Sudhakaran"]

उदाहरण

<script>
   const marks = [10,20,30,40]
   console.log(Object.entries(marks))
   console.log(Object.values(marks))
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

["0", 10],
["1", 20],
["2", 30],
["3", 40]
]
[10, 20, 30, 40]

उदाहरण

<script>
   const student = {
      firstName : 'Mohtashim',
      lastName: 'Mohammad',
      get fullName(){
         return this.firstName + ':'+ this.lastName
      }
   }
   console.log(Object.getOwnPropertyDescriptors(student))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

{firstName: {value: "Mohtashim", writable: true, enumerable: true, configurable: true}
fullName: {get: ƒ, set: undefined, enumerable: true, configurable: true}
lastName: {value: "Mohammad", writable: true, enumerable: true, configurable: true}
}

Async और Await

Async / Await ES8 में एक बहुत ही महत्वपूर्ण विशेषता है। यह जावास्क्रिप्ट में प्रॉमिस के लिए एक सिंटैक्टिक चीनी है। प्रतीक्षित कीवर्ड का उपयोग वादों के साथ किया जाता है। इस कीवर्ड का उपयोग किसी वादे के निपटारे तक किसी कार्य के निष्पादन को रोकने के लिए किया जा सकता है। प्रतीक्षित कीवर्ड वादा का मूल्य लौटाता है यदि वादा खारिज कर दिया जाता है, तो यह वादा हल हो जाता है। प्रतीक्षित फ़ंक्शन का उपयोग केवल async के रूप में चिह्नित कार्यों के अंदर ही किया जा सकता है। एक फ़ंक्शन जिसे async कीवर्ड का उपयोग करके घोषित किया जाता है, हमेशा एक वादा वापस करता है।

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

प्रतीक्षा के साथ async फ़ंक्शन का सिंटैक्स नीचे दिया गया है -

async function function_name(){
   let result_of_functionCall = await longRunningMethod();
}
//invoking async function

function_name().then(()=>{})
   .catch(()=>{})

एक ऐसे उदाहरण पर विचार करें जिसमें एक एसिंक्रोनस फ़ंक्शन होता है जो स्ट्रिंग मान को निष्पादित करने और वापस करने में दो सेकंड लेता है। फ़ंक्शन को दो तरीकों से लागू किया जा सकता है जैसा कि नीचे दिखाया गया है

  • वादे का उपयोग करना। ()
  • Aync / प्रतीक्षा का उपयोग करना।

नीचे दिया गया कोड पारंपरिक ES6 सिंटैक्स - वादे.थेन () का उपयोग करके अतुल्यकालिक फ़ंक्शन को लागू करता है।

<script>
   function fnTimeConsumingWork(){
      return new Promise((resolve,reject)=>{
         setTimeout(() => {
            resolve('response is:2 seconds have passed')
         }, 2000);
      })
   }

   fnTimeConsumingWork().then(resp=>{
      console.log(resp)
   })
   console.log('end of script')
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

end of script
response is:2 seconds have passed

नीचे दिए गए कोड में ES8 सिंटैक्स - async / प्रतीक्षा का उपयोग करके अतुल्यकालिक फ़ंक्शन को लागू करने का एक क्लीनर तरीका दिखाया गया है

<script>
   function fnTimeConsumingWork(){
      return new Promise((resolve,reject)=>{
         setTimeout(() => {
            resolve('response is:2 seconds have passed')
         }, 2000);
      })
   }
   async function my_AsyncFunc(){
      console.log('inside my_AsyncFunc')
      const response = await fnTimeConsumingWork();// clean and readable
      console.log(response)
   }
   my_AsyncFunc();
   console.log("end of script")
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

inside my_AsyncFunc
end of script
response is:2 seconds have passed

Async / प्रतीक्षा के साथ वादा करने का वादा

निम्नलिखित उदाहरण लागू होता है async / प्रतीक्षा सिंटैक्स का उपयोग करते हुए वादा करता हूँ।

इस उदाहरण में, add_positivenos_async()फ़ंक्शन दो संख्याओं को अतुल्यकालिक रूप से जोड़ता है और यदि नकारात्मक मान पारित किए जाते हैं तो अस्वीकार कर देता है। वर्तमान अतुल्यकालिक फ़ंक्शन कॉल से परिणाम बाद के फ़ंक्शन कॉल के पैरामीटर के रूप में पारित किया जाता है।

<script>
   function add_positivenos_async(n1, n2) {
      let p = new Promise(function (resolve, reject) {
         if (n1 >= 0 && n2 >= 0) {
            //do some complex time consuming work
            resolve(n1 + n2)
         } else
            reject('NOT_Postive_Number_Passed')
      })
      return p;
   }
   async function addInSequence() {
      let r1 = await add_positivenos_async(10, 20)
      console.log("first result", r1);
      let r2 = await add_positivenos_async(r1, r1);
      console.log("second result", r2)
      let r3 = await add_positivenos_async(r2, r2);
      console.log("third result", r3)
      return "Done Sequence"
   }
   addInSequence().then((r)=>console.log("Async :",r));
   console.log('end')
</script>

उपरोक्त कोड का आउटपुट नीचे दिया जाएगा

end
first result 30
second result 60
third result 120
Async : Done Sequence