ईएस 6 - वादे

वादा सिंटेक्स

वचन से संबंधित सिंटैक्स का उल्लेख नीचे किया गया है, जहां, p वादा वस्तु है, resolve वह फ़ंक्शन है जिसे तब कॉल किया जाना चाहिए जब वादा सफलतापूर्वक निष्पादित होता है और reject फ़ंक्शन वह है जिसे तब कॉल किया जाना चाहिए जब वादा एक त्रुटि का सामना करता है।

let p = new Promise(function(resolve,reject){
   let workDone = true; // some time consuming work
      if(workDone){
      //invoke resolve function passed
      
	  resolve('success promise completed')
   }
   else{
      reject('ERROR , work could not be completed')
   }
})

उदाहरण

नीचे दिया गया उदाहरण एक फ़ंक्शन दिखाता है 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;
   }

   add_positivenos_async(10, 20)
      .then(successHandler) // if promise resolved
      .catch(errorHandler);// if promise rejected

   add_positivenos_async(-10, -20)
      .then(successHandler) // if promise resolved
      .catch(errorHandler);// if promise rejected

   function errorHandler(err) {
      console.log('Handling error', err)
   }
   function successHandler(result) {
      console.log('Handling success', result)
   }

   console.log('end')
</script>

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

end
Handling success 30
Handling error NOT_Postive_Number_Passed

चैनिंग का वादा किया

Promises chaining जब हम एक अनुक्रम है इस्तेमाल किया जा सकता है asynchronous tasksएक के बाद एक किया जाना। जब एक वादा दूसरे वादे के परिणाम पर निर्भर करता है तो वादे जंजीर होते हैं। यह नीचे दिए गए उदाहरण में दिखाया गया है

उदाहरण

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

<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;
   }

   add_positivenos_async(10,20)
   .then(function(result){
      console.log("first result",result)
      return add_positivenos_async(result,result)
   }).then(function(result){
   console.log("second result",result)
      return add_positivenos_async(result,result)
   }).then(function(result){
      console.log("third result",result)
   })

   console.log('end')
</script>

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

end
first result 30
second result 60
third result 120

वादा वस्तु के कुछ सामान्य उपयोग के तरीकों पर नीचे विस्तार से चर्चा की गई है -

promise.all ()

यह विधि कई वादों के परिणामों को एकत्र करने के लिए उपयोगी हो सकती है।

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

के लिए वाक्यविन्यास promise.all() विधि का उल्लेख नीचे दिया गया है, जहां, iterableएक चलने योग्य वस्तु है। जैसे ऐरे।

Promise.all(iterable);

उदाहरण

नीचे दिया गया उदाहरण अतुल्यकालिक संचालन की एक सरणी निष्पादित करता है [add_positivenos_async(10,20),add_positivenos_async(30,40),add_positivenos_async(50,60)]। जब सभी ऑपरेशन पूरे हो जाते हैं, तो वादा पूरी तरह से हल हो जाता है।

<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;
   }
   //Promise.all(iterable)

Promise.all([add_positivenos_async(10,20),add_positivenos_async(30,40),add_positivenos_async(50,60)])
   .then(function(resolveValue){
      console.log(resolveValue[0])
      console.log(resolveValue[1])
      console.log(resolveValue[2])
      console.log('all add operations done')
   })
   .catch(function(err){
      console.log('Error',err)
   })
   console.log('end')
</script>

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

end
30
70
110
all add operations done

promise.race ()

यह फ़ंक्शन वादों की एक सरणी लेता है और पहले वादे का निपटान करता है।

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

के लिए वाक्यविन्यास promise.race()फ़ंक्शन का उल्लेख नीचे किया गया है, जहां, पुनरावृत्त एक चलने योग्य वस्तु है। जैसे ऐरे।

Promise.race(iterable)

उदाहरण

नीचे दिया गया उदाहरण एक सरणी लेता है [add_positivenos_async(10,20),add_positivenos_async(30,40)] अतुल्यकालिक संचालन के।

जब भी ऐड ऑपरेशन में से कोई भी पूरा होता है तो वादा हल किया जाता है। वादा अन्य अतुल्यकालिक संचालन के पूरा होने का इंतजार नहीं करेगा।

<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;
   }

   //Promise.race(iterable)
   Promise.race([add_positivenos_async(10,20),add_positivenos_async(30,40)])
   .then(function(resolveValue){
      console.log('one of them is done')
      console.log(resolveValue)
   }).catch(function(err){
      console.log("Error",err)
   })

   console.log('end')
</script>

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

end
one of them is done
30

Promisesजावास्क्रिप्ट (ES6 नई सुविधा) में async प्रोग्रामिंग को लागू करने का एक साफ तरीका है। वादों से पहले, कॉलबैक का उपयोग एसिंक्स प्रोग्रामिंग को लागू करने के लिए किया गया था। आइए, कॉलबैक का उपयोग करके यह बताएं कि Async प्रोग्रामिंग क्या है और इसका कार्यान्वयन क्या है।

कॉलबैक को समझना

एक फ़ंक्शन को दूसरे फ़ंक्शन के पैरामीटर के रूप में पारित किया जा सकता है। इस तंत्र को एक के रूप में कहा जाता हैCallback। एक कॉलबैक घटनाओं में सहायक होगा।

निम्नलिखित उदाहरण हमें इस अवधारणा को बेहतर ढंग से समझने में मदद करेंगे।

<script>   
   function notifyAll(fnSms, fnEmail) {   
      console.log('starting notification process');   
      fnSms();   
      fnEmail();   
   }   
   notifyAll(function() {   
      console.log("Sms send ..");   
   }, 
   function() {   
      console.log("email send ..");   
   });   
   console.log("End of script"); 
   //executes last or blocked by other methods   
</script>

में notifyAll()ऊपर दिखाया गया तरीका, अधिसूचना एसएमएस भेजकर और ई-मेल भेजकर होती है। इसलिए, InformAll विधि के आक्रमणकर्ता को दो कार्यों को मापदंडों के रूप में पारित करना होगा। प्रत्येक फ़ंक्शन एसएमएस भेजने और ई-मेल भेजने जैसी एकल जिम्मेदारी लेता है।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

starting notification process 
Sms send .. 
Email send .. 
End of script

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

AsyncCallback को समझना

उपरोक्त उदाहरण पर विचार करें।

स्क्रिप्ट को सक्षम करने के लिए, अतुल्यकालिक या गैर-अवरोधक कॉल को InformAll () विधि से निष्पादित करें। हम उपयोग करेंगेsetTimeout()जावास्क्रिप्ट की विधि। यह विधि डिफ़ॉल्ट रूप से async है।

सेटटाइमआउट () विधि में दो पैरामीटर हैं -

  • एक कॉलबैक फ़ंक्शन।

  • सेकंड की संख्या जिसके बाद विधि को बुलाया जाएगा।

इस मामले में, अधिसूचना प्रक्रिया को टाइमआउट के साथ लपेटा गया है। इसलिए, कोड द्वारा निर्धारित दो सेकंड की देरी होगी। इनफॉर्मल () को लागू किया जाएगा और मुख्य धागा अन्य तरीकों को निष्पादित करने की तरह आगे बढ़ता है। इसलिए, अधिसूचना प्रक्रिया मुख्य जावास्क्रिप्ट थ्रेड को ब्लॉक नहीं करेगी।

<script>   
   function notifyAll(fnSms, fnEmail) {   
      setTimeout(function() {   
         console.log('starting notification process');   
         fnSms();   
         fnEmail();   
      }, 2000);   
   }   
   notifyAll(function() {   
      console.log("Sms send ..");   
   },  
   function() {   
      console.log("email send ..");   
   });   
   console.log("End of script"); //executes first or not blocked by others   
</script>

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

End of script 
starting notification process 
Sms send .. 
Email send ..

कई कॉलबैक के मामले में, कोड डरावना लगेगा।

<script>   
   setTimeout(function() {   
      console.log("one");   
      setTimeout(function() {   
         console.log("two");   
         setTimeout(function() {   
            console.log("three");   
         }, 1000);   
      }, 1000);   
   }, 1000);   
</script>

ईएस 6 वादों की अवधारणा को पेश करके आपके बचाव में आता है। वादे "कंटीन्यू ईवेंट्स" होते हैं और वे आपको एक बहुत क्लीनर कोड शैली में एक साथ कई एसिंक्स ऑपरेशंस को निष्पादित करने में मदद करते हैं।

उदाहरण

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

var promise = new Promise(function(resolve , reject) {    
   // do a thing, possibly async , then..  
   if(/*everthing turned out fine */)    resolve("stuff worked");  
   else     
   reject(Error("It broke"));  
});  
return promise;
// Give this to someone

वादों को लागू करने की दिशा में पहला कदम एक ऐसी विधि तैयार करना है जो वादे का उपयोग करेगी। आइए इस उदाहरण में कहते हैं,getSum()विधि अतुल्यकालिक है अर्थात्, इसका संचालन अन्य तरीकों के निष्पादन को अवरुद्ध नहीं करना चाहिए। जैसे ही यह ऑपरेशन पूरा होता है, यह बाद में कॉलर को सूचित करेगा।

निम्न उदाहरण (चरण 1) एक वादा वस्तु 'var वादा' की घोषणा करता है। प्रॉमिस कंस्ट्रक्टर कार्य के सफल समापन के लिए पहले कार्यों में ले जाता है और दूसरे में त्रुटि होने पर।

वादा कॉलबैक का उपयोग करके और परिणाम में पास होने के द्वारा गणना का परिणाम देता है, अर्थात, n1 + n2

Step 1 - संकल्प (n1 + n2);

यदि getSum () एक त्रुटि या अप्रत्याशित स्थिति का सामना करता है, तो यह वादा में अस्वीकार कॉलबैक विधि को आमंत्रित करेगा और कॉल करने वाले को त्रुटि जानकारी पारित करेगा।

Step 2 - अस्वीकार (त्रुटि ("नकारात्मक समर्थित नहीं"));

विधि कार्यान्वयन निम्नलिखित कोड (STEP 1) में दिया गया है।

function getSum(n1, n2) {   
   varisAnyNegative = function() {   
      return n1 < 0 || n2 < 0;   
   }   
   var promise = new Promise(function(resolve, reject) {   
      if (isAnyNegative()) {   
         reject(Error("Negatives not supported"));   
      }   
      resolve(n1 + n2)
   });   
   return promise;   
}

दूसरे चरण में कॉलर के कार्यान्वयन का विवरण (STEP 2) है।

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

getSum(5, 6)   
.then(function (result) {   
   console.log(result);   
},   
function (error) {   
   console.log(error);   
});

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

11

चूंकि गेटसम का वापसी प्रकार () एक वादा है, हम वास्तव में कई 'फिर' बयान दे सकते हैं। पहले 'फिर' में रिटर्न स्टेटमेंट होगा।

getSum(5, 6)   
.then(function(result) {   
   console.log(result);   
   returngetSum(10, 20); 
   // this returns another promise   
},   
function(error) {   
   console.log(error);   
})   
.then(function(result) {   
   console.log(result);   
}, 
function(error) {   
   console.log(error);
});

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

11
30

निम्न उदाहरण तीन तब जारी करता है () getSum () विधि के साथ कॉल करता है।

<script>   
   function getSum(n1, n2) {   
      varisAnyNegative = function() {   
         return n1 < 0 || n2 < 0;   
      }   
      var promise = new Promise(function(resolve, reject) {   
         if (isAnyNegative()) {   
            reject(Error("Negatives not supported"));   
         }   
         resolve(n1 + n2);   
      });   
      return promise;   
   }   
   getSum(5, 6)   
   .then(function(result) {   
      console.log(result);   
      returngetSum(10, 20); 
      //this returns another Promise   
   },   
   function(error) {   
      console.log(error);   
   })
   .then(function(result) {   
      console.log(result);   
      returngetSum(30, 40); 
      //this returns another Promise   
   }, 
   function(error) {   
      console.log(error);   
   })   
   .then(function(result) {   
      console.log(result);   
   }, 
   function(error) {         
      console.log(error);   
   });   
   console.log("End of script ");   
</script>

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

कार्यक्रम पहले 'स्क्रिप्ट का अंत' प्रदर्शित करता है और फिर गेटसम () विधि से, एक-एक करके कॉल करता है।

End of script  
11 
30 
70

यह पता चलता है getSum () को async स्टाइल या नॉन-ब्लॉकिंग स्टाइल में कहा जाता है। वादा कॉलबैक से निपटने के लिए एक अच्छा और साफ तरीका देता है।