जावास्क्रिप्ट प्रतीक्षा
exp |
JavaScript |
log |
mean |
sin
Michael Zippo
ES6 में पेश किया गया, प्रॉमिस आपको कई कॉलबैक फ़ंक्शंस से निपटने के बिना आसानी से एसिंक्रोनस कोड लिखने की अनुमति देता है। वादों के साथ, बहु-स्तरीय कॉलबैक के बारे में चिंता करने की कोई आवश्यकता नहीं है, जिन्हें लिखना और बनाए रखना दोनों ही कठिन हैं। / भाग लेना। ये - ये आपको कोड लिखने की अनुमति देते हैं जो सिंक्रोनस लुक करता है लेकिन एसिंक्रोनस रूटीन बनाता है।
इस गाइड में, हम चर्चा करने जा रहे हैं कि एसिंक्रोनस / प्रतीक्षा फ़ंक्शन क्या है और आप इसे अपने कोड में कैसे उपयोग कर सकते हैं। आइए शुरू करें
वादे: एक पुनश्चर्या
इससे पहले कि हम अतुल्यकालिक / प्रतीक्षा कार्यों के बारे में बात करना शुरू करें, हमें वादों को फिर से लिखना होगा। एक वादा एक अतुल्यकालिक ऑपरेशन का प्रतिनिधित्व करता है। कोड इंगित करता है कि एक ऑपरेशन किया जाएगा, और यदि ऑपरेशन सफल होता है, तो एक मान वापस कर दिया जाएगा। अन्यथा, शेष कार्यक्रम में एक त्रुटि लौटा दी जाएगी।
एक वादा एक ऐसे मूल्य का प्रतिनिधित्व करता है जो उस समय ज्ञात नहीं था जब वादा किया गया था। एक वादा बस इतना है: एक वादा कि भविष्य के मूल्य ‚Äã‚Äãआपके कोड पर वापस आ जाएंगे। चूंकि वादा एक वस्तु है, यह सभी कैप में होना चाहिए।
इस परिदृश्य पर विचार करें। आपको एपीआई से संसाधन पुनर्प्राप्त करने की आवश्यकता है। आपके अनुरोध को संसाधित करने में एक या दो सेकंड का समय लगेगा। उपयोगकर्ता द्वारा अनुरोध के संसाधित होने की प्रतीक्षा करने के बजाय, आप अपने कोड को एक प्रॉमिस में स्थानांतरित कर सकते हैं ताकि आपका शेष प्रोग्राम कार्य करना जारी रख सके। डेटा निकालते समय वेबसाइट UI। जैसे ही कोई मान लौटाया जाता है, प्रॉमिस आपके मुख्य प्रोग्राम को भेज देगा।
यहां एक वादे का उदाहरण दिया गया है:.
हमारा कोड फ़ीडबैक: आपकी कुकी भेज दी गई हैं! जब हम SendCookies.then () विधि निष्पादित करें, हमारा वादा जारी किया गया है। हमारा प्रोग्राम 1000 मिलीसेकंड प्रतीक्षा करता है, फिर "आपकी कुकीज़ भेज दी गई है!" "हमारा मुख्य कार्यक्रम
Async और प्रतीक्षा का उपयोग कैसे करें
एक फ़ंक्शन और async / प्रतीक्षा में, एक कोड निष्पादन प्रतीक्षा कथन अपने एसिंक्रोनस फ़ंक्शन के भीतर ब्लॉक करता है जब तक कि `जिस पर एक वादा वापस नहीं किया जाता है। यही कारण है कि डेवलपर्स अक्सर दावा करते हैं कि एसिंक्रोनस / एसिंक्रोनस प्रतीक्षा कार्य करता है लेकिन एसिंक्रोनस कार्यों को निष्पादित करता है।
निम्न उदाहरण पर विचार करें:। ">
sendCookies फ़ंक्शन () {नया वादा लौटाएं (संकल्प => {सेटटाइमआउट (() => {निर्धारण ("आपकी कुकीज़ भेज दी गई हैं")!}, 1000);}); } मुख्य async फ़ंक्शन () {कॉन्स्ट सेंडमैसेज = प्रतीक्षा करें सेंडकुक यानी (); कंसोल.लॉग (भेजें संदेश); } (मुख्य);
हमारा कोड फ़ीडबैक: आपकी कुकी भेज दी गई हैं! हमारे SendCookies () फ़ंक्शन को "आपकी कुकीज़ भेज दी गई है" मान वापस करने में 1000 मिलीसेकंड का समय लगता है। इस मामले में, हमने एक एसिंक्रोनस फ़ंक्शन घोषित किया है ताकि हमारा कोड एक वादे के समाधान या अस्वीकार किए जाने की प्रतीक्षा कर रहा है।
"async" फ़ंक्शन कीवर्ड हमारे कोड को बताता है कि हम एक एसिंक्रोनस प्रदर्शन करना चाहते हैं हमारे समारोह में संचालन। "उम्मीद" शब्द - कुंजी इंगित करता है कि हमारे कोड को भेजने के लिए प्रतीक्षा करें () हमारे प्रोग्राम को निष्पादित करने से पहले वापस लौटने का वादा करता है।
एसिंक्रोनस फ़ंक्शन हमेशा एक वादा लौटाते हैं।
Async और साथ का उपयोग करना मल्टीपल पास वेट
एसिंक्रोनस / वेट फंक्शन का सबसे अधिक उपयोग तब किया जाता है जब कई वादे होते हैं जिनके साथ आपको काम करने की आवश्यकता होती है। इसे कभी-कभी चेनिंग वादे कहा जाता है। वास्तव में, आपका कोड अगले चरण पर जाने से पहले प्रत्येक चरण पर लौटने के वादे की प्रतीक्षा करेगा:
हमारा कोड रिटर्न:
प्रत्येक चरण में 1000 पूर्ण मिलीसेकंड लगते हैं!. हमारे SendCookies () फ़ंक्शन को तब तक निष्पादित नहीं किया जाता है जब तक कि हमारे ProcessOrder () फ़ंक्शन से वापसी का वादा नहीं किया जाता है। /p>
पहला वह तरीका है जो हमने अपने पिछले उदाहरणों में दिखाया था: फंक्शन घोषित करके। हमारे उदाहरणों में, हमने ऐसे कार्यों की घोषणा की जो एक वादा लौटाते हैं, इसलिए हमने "async" और "उम्मीद" शब्दों का उपयोग किया - इन कार्यों को करने के लिए कुंजी
आप दिशा कार्यों का उपयोग करके एक अतुल्यकालिक फ़ंक्शन भी घोषित कर सकते हैं:
यह कोड लौटाता है: आपकी कुकीज़ भेज दी गई हैं! यह हमारे पहले उदाहरण के समान है, लेकिन मुख्य () फ़ंक्शन घोषित करने के बजाय हमने एक तीर फ़ंक्शन का उपयोग किया
इसी तरह आप फ़ंक्शन के एक्सप्रेशन सिंटैक्स का उपयोग कर सकते हैं:। (); कंसोल.लॉग (sendMessage);}
यह रिटर्न कोड: आपकी कुकी भेज दी गई हैं जैसा कि आप देख सकते हैं, आउटपुट फिर से l या स्वयं है। फर्क सिर्फ इतना है कि हमने अपने फ़ंक्शन को कैसे घोषित किया।
वास्तव में, यह सिंटैक्स हमारे पिछले उदाहरण के समान है। बूम फ़ंक्शन का उपयोग करने के स्थान पर हम केवल - कुंजी "फ़ंक्शन ()" शब्द का उपयोग करते हैं।
एसिंक्रोनस / प्रतीक्षा फ़ंक्शन को घोषित करने का इससे बेहतर तरीका कोई नहीं है। यह सब आपके द्वारा लिखे जा रहे प्रोग्राम और आपके द्वारा पसंद किए जाने वाले सिंटैक्स पर निर्भर करता है। हालांकि यह तर्क दिया जा सकता है कि निर्देशन कार्य सबसे संक्षिप्त विधि है, अन्य मामलों में एसिंक्रोनस / प्रतीक्षा फ़ंक्शन घोषित करने के अन्य तरीके बेहतर हो सकते हैं।
Async / Wait का उपयोग करके वेब अनुरोधों को संसाधित करना
एक वादा-आधारित एपीआई, फ़ेच अस () के साथ वेब अनुरोधों को संसाधित करने के लिए एसिंक / प्रतीक्षा फ़ंक्शन के सबसे आम उपयोगों में से एक है। आप खोज करने के लिए हमारी जावास्क्रिप्ट शुरुआती मार्गदर्शिका में फ़ेच () का उपयोग करने के तरीके के बारे में अधिक पढ़ सकते हैं
आइए इस उदाहरण को लेते हैं:
हमारा कोड रिटर्न:
जब हम अपना रिट्रीव कमेंट () फंक्शन चलाते हैं, तो हम "वेट" वर्ड - की फंक्शन टू वेट का प्रयोग करते हैं। () स्टेटमेंट। इसका मतलब है कि हमारा बाकी शेड्यूल तब तक जारी नहीं रहेगा जब तक कि हमारा वेब अनुरोध संसाधित नहीं हो जाता। वास्तव में, फ़ंक्शन एक वादा लौटाता है।
जब कोई वादा फ़ेच () फ़ंक्शन फ़ेच द्वारा वापस किया जाता है (), हम उस मान को जेएसओएन में बदल देते हैं। फिर हम सभी टिप्पणियों के नामों की सूची लाने के लिए ऑब्जेक्ट की पहचान करते हैं और इसे कंसोल पर प्रिंट करते हैं
त्रुटि को कैसे हैंडल करें का उपयोग करके किसी ईवेंट को सक्रिय करें h2>
ओह, जैसे मैं चाहता हूं कि कोड में त्रुटियां न हों। लेकिन वे करते हैं, और वहां डेवलपर्स को हमें कुछ योजना बनानी होगी। एसिंक्रोनस फ़ंक्शन, एरर हैंडलिंग एक सिंक्रोनस ट्राई ... कैच का उपयोग करके किया जाता है। इस कोड पर विचार करें:.
हमारा कोड लौटाता है:
हमारे उदाहरण में, यदि कोई वापस आता है तो हमने .catch () का उपयोग किया है। इस मामले में, हम अपने कोड को यह बताने के लिए आवश्यकता ("त्रुटि") का उपयोग करते हैं कि एक त्रुटि हुई है।
यदि यह कथन निष्पादित किया जाता है, तो हमारी .catch () घोषणा शुरू हो जाती है और त्रुटि मुद्रित हो जाती है।
इसी तरह, एसिंक्रोनस फ़ंक्शन सिंटैक्स त्रुटियों का पता लगा सकते हैं:। res = प्रतीक्षा करें (`https://thisapidoesnotexist.app/cookies`); var कुकीनाम = प्रतीक्षा करें res.json (); कुकीनाम = कुकीनाम.मैप (कुकी => कुकी.नाम); निर्णय (कुकी नाम); } एसिंक्रोनस फंक्शन PrintCookies () {{ const टेस्ट = कुकीज रिट्रीव होने की प्रतीक्षा करेंकुकीज (); कंसोल.लॉग (गवाह); } कैच (त्रुटि) {console.log (त्रुटि); }} प्रिंटकुकीज़ ();
हमारा कोड लौटाता है: संसाधन प्राप्त करने का प्रयास करते समय NetworkError। इस उदाहरण में, हमने यह जांचने के लिए एक कोशिश / पकड़ विवरण का उपयोग किया कि क्या हमारी प्रतीक्षा पद्धति ने सफलता का वादा किया है। फिर से , हमारा एपीआई अमान्य है जिसके कारण हमारा कार्यक्रम हमारे वादे को अस्वीकार कर रहा है। जब ऐसा होता है, तो "कैच" को हमारे ट्राई / कैच ब्लॉक में निष्पादित किया जाता है, जो हमारी त्रुटि को कंसोल में लॉग करता है। कोड में। जब एक अतुल्यकालिक फ़ंक्शन घोषित किया जाता है, तो आप संचालन के परिणाम की प्रतीक्षा करने के लिए "प्रतीक्षा" शब्द - कुंजी का उपयोग कर सकते हैं। प्रतीक्षा कीवर्ड का उपयोग एक ऐसे फ़ंक्शन के साथ किया जाना चाहिए जो एक वादा लौटाता है।
अब आप इसके लिए तैयार हैं एसिंक्रोनस जावास्क्रिप्ट फ़ंक्शंस का उपयोग करें / एक विशेषज्ञ की तरह प्रतीक्षा करें!
Shop
Learn programming in R: courses
$
Best Python online courses for 2022
$
Best laptop for Fortnite
$
Best laptop for Excel
$
Best laptop for Solidworks
$
Best laptop for Roblox
$
Best computer for crypto mining
$
Best laptop for Sims 4
$
Latest questions
NUMPYNUMPY
psycopg2: insert multiple rows with one query
12 answers
NUMPYNUMPY
How to convert Nonetype to int or string?
12 answers
NUMPYNUMPY
How to specify multiple return types using type-hints
12 answers
NUMPYNUMPY
Javascript Error: IPython is not defined in JupyterLab
12 answers
Wiki
Python OpenCV | cv2.putText () method
numpy.arctan2 () in Python
Python | os.path.realpath () method
Python OpenCV | cv2.circle () method
Python OpenCV cv2.cvtColor () method
Python - Move item to the end of the list
time.perf_counter () function in Python
Check if one list is a subset of another in Python
Python os.path.join () method