ईएस 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 स्टाइल या नॉन-ब्लॉकिंग स्टाइल में कहा जाता है। वादा कॉलबैक से निपटने के लिए एक अच्छा और साफ तरीका देता है।