सुनो! क्या आप कभी अपने जावास्क्रिप्ट कोड में शून्य या अपरिभाषित मानों को संभालने का प्रयास करते समय निराश हुए हैं? नुलिश कोलेसिंग एक नई सुविधा है जो इसे बहुत आसान बनाने में मदद करती है। इस पोस्ट में, हम शून्य सहसंयोजन की व्याख्या करेंगे। इसका मतलब है सरल शब्द, मज़ेदार उदाहरण और कोई जटिल शब्दजाल नहीं। अंत तक, आप कुछ ही समय में साफ़, संक्षिप्त जेएस कोड लिख लेंगे। तो वास्तव में शून्य सहसंयोजन क्या है? मूल रूप से, जब कोई चीज़ शून्य या अपरिभाषित होती है तो यह डिफ़ॉल्ट मान प्रदान करने का एक छोटा, सरल तरीका है। अव्यवस्थित नेस्टेड टर्नरीज़ या तार्किक OR कथनों के बजाय, आप डिफ़ॉल्ट में एकजुट होने के लिए दोहरे प्रश्न चिह्न ऑपरेटर (??) का उपयोग कर सकते हैं। भ्रमित करने वाला लग रहा है? चिंता न करें, हम आपको कुछ आसान उदाहरणों के साथ दिखाएंगे कि यह कैसे काम करता है। कमर कस लें, यह एक मज़ेदार सवारी होने वाली है! नुलिश कोलेसिंग ऑपरेटर वास्तव में क्या है?? क्या आप कभी जावास्क्रिप्ट में शून्य मानों से निपटने में फंस गए हैं? मुझे पता है मेरे पास है। ठीक है, मेरे दोस्त, मैं तुम्हें शून्य कोलेस्सिंग ऑपरेटर (??) से परिचित कराता हूँ। यह छोटा लड़का आपके जीवन को बहुत आसान बना देगा। तो वास्तव में नॉलिश कोलेसिंग ऑपरेटर क्या है? मूल रूप से, यह एक डिफ़ॉल्ट मान प्रदान करने का एक शॉर्टकट है जब कुछ शून्य या अपरिभाषित हो सकता है। लिखने के बजाय: let name = obj.name || 'default name'; अब आप बस लिख सकते हैं: let name = obj.name ?? 'default name'; ?? यदि यह शून्य नहीं है (मतलब शून्य या अपरिभाषित है), तो ऑपरेटर बाईं ओर लौटाएगा, अन्यथा, यह दाईं ओर लौटाएगा। तो उपरोक्त उदाहरण में, यदि शून्य या अपरिभाषित नहीं है, तो नाम पर सेट किया जाएगा। लेकिन यदि शून्य या अपरिभाषित है, तो नाम 'डिफ़ॉल्ट नाम' होगा। obj.name obj.name obj.name बहुत सुविधाजनक, है ना? कुछ अन्य उदाहरण: let age = ageInput ?? 25; // Sets age to ageInput if not nullish, otherwise 25 let email = user.email ?? 'no email provided'; let hobbies = obj.hobbies ?? []; // Sets hobbies to obj.hobbies if not nullish, otherwise an empty array मुझे आशा है कि यह जावास्क्रिप्ट में आपके कुछ सशर्त तर्क को सरल बनाने में मदद करेगा। एक वास्तविक दुनिया का उदाहरण जिससे हम सभी जुड़ सकते हैं क्या आप कभी किसी चीज़ के लिए भुगतान करने गए हैं और आपको एहसास हुआ है कि आपके पास कुछ रुपये कम हैं? हम सभी वहाँ रहे है। शून्य संयोजन आपकी जेब में कुछ अतिरिक्त डॉलर ढूंढने जैसा है ताकि आप वास्तव में वह खरीद सकें जो आप खरीदना चाहते हैं। मान लीजिए कि आप अपने सामान्य सुबह के पेय के लिए अपनी पसंदीदा कॉफ़ी शॉप पर जाते हैं। आप हाथ में $3 लेकर ऑर्डर के लिए तैयार होकर काउंटर पर जाएँ। लेकिन जब बरिस्ता आपको आपका कुल योग बताता है, तो कर के बाद यह $3.50 निकलता है। अचानक याद आने जैसा है कि आपकी जेब में एक और डॉलर है, इसलिए आप अभी भी अपनी कॉफी प्राप्त कर सकते हैं। काहे! अशक्त सहवास जावास्क्रिप्ट में, यदि कुछ शून्य या अपरिभाषित हो जाता है तो एक डिफ़ॉल्ट मान प्रदान करने का एक तरीका है। उदाहरण के लिए, मान लें कि आपके पास एक फ़ंक्शन है जो मान लौटा भी सकता है और नहीं भी: शून्य सहसंयोजन function getCoffeePrice() { // Returns $3.50 or undefined } let price = getCoffeePrice() ?? '$3.50'; यहां, यदि अपरिभाषित लौटाता है, तो डिफ़ॉल्ट रूप से होगी धन्यवाद शून्य सह-संचालन संचालक। तो आपको किसी भी तरह से अपनी कॉफ़ी की कीमत की गारंटी है। getCoffeePrice() price '$3.50' ?? जब वेरिएबल शून्य या अपरिभाषित होते हैं, तो शून्य सहसंयोजन फ़ॉलबैक डिफ़ॉल्ट मान प्रदान करके आपके कोड को अधिक लचीला बनाता है। कॉफ़ी शॉप में अपनी जेब में अतिरिक्त डॉलर ढूंढने की तरह, यह सुनिश्चित करता है कि लेन-देन पूरा करने के लिए आपके पास वह सब कुछ है जो आपको चाहिए। बहुत सुविधाजनक, है ना? अब आप यह जानकर निश्चिंत हो सकते हैं कि आप एक पेशेवर की तरह शून्य संयोजन को समझते हैं। कोडिंग का आनंद लें और अपनी कॉफी का आनंद लें! जावास्क्रिप्ट में न्यूलिश कोलेसिंग का उपयोग करना यदि यह शून्य नहीं है, तो शून्य सहसंयोजक ऑपरेटर (??) अपना बायां ऑपरेंड लौटाता है; अन्यथा, यह अपना दायां ऑपरेंड लौटाता है। अस्पष्ट? आइए इसे तोड़ें। एक "शून्य" मान या तो शून्य या अपरिभाषित होता है। तो ऑपरेटर जाँचता है कि क्या बायाँ मान शून्य है, और यदि ऐसा है, तो इसके बजाय सही मान लौटाता है। ?? उदाहरण के लिए: const name = bob ?? 'anonymous'; यदि बॉब परिभाषित है तो यह 'बॉब' को नाम का मान निर्दिष्ट करेगा। यदि बॉब अपरिभाषित या शून्य है, तो यह इसके बजाय 'अनाम' स्ट्रिंग निर्दिष्ट करेगा। यह उपयोगी क्यों है? के बिना ?? ऑपरेटर, आपको यह करना होगा: const name = bob !== null && bob !== undefined ? bob : 'anonymous'; ?? ऑपरेटर हमें अनिवार्य रूप से वही कार्य करने के लिए एक छोटा, साफ़ सिंटैक्स देता है। इसका उपयोग जावास्क्रिप्ट में कहीं भी किया जा सकता है - , , ऑब्जेक्ट गुणों आदि में। कहीं भी आप आमतौर पर || का उपयोग करेंगे। (या) डिफ़ॉल्ट मानों के लिए ऑपरेटर, अब आप उपयोग कर सकते हैं ?? "शून्य" डिफ़ॉल्ट मान के लिए। वेरिएबल्स फ़ंक्शन तर्क कुछ उदाहरण: const foo = null ?? 'default string'; // foo is 'default string' const bar = 0 ?? 42; // bar is 0 const qux = 0 || 42; // qux is 42 - || returns first truthy value function doSomething(x = 0) { x = x ?? 10; // If x is nullish, set default of 10 console.log(x); } doSomething(null); // Prints 10 doSomething(5); // Prints 5 मुझे आशा है कि इससे निरर्थक सह-संचालन ऑपरेटर को समझाने में मदद मिलेगी! क्यों शून्य सहसंयोजन OR से बेहतर है (||) OR (||) ऑपरेटर पहला सत्य मान लौटाएगा। OR (||) ऑपरेटर अपने सामने आने वाले पहले सत्य मान को लौटाकर काम करता है। यदि दोनों मान ग़लत हैं, तो यह अंतिम मान लौटाएगा। उदाहरण के लिए: let name = null; let user = name || 'John'; // user is 'John' यहां, शून्य (झूठा) है, इसलिए दूसरा मान, 'जॉन' मिलता है। name user नुलिश कोलेसिंग ऑपरेटर (??) अधिक स्मार्ट है। नुलिश कोलेसिंग ऑपरेटर (??) को ES2020 में पेश किया गया था और यह OR (||) से थोड़ा अधिक स्मार्ट है। यह पहला परिभाषित मान लौटाएगा (शून्य/अपरिभाषित नहीं)। इसलिए यदि पहला मान एक खाली स्ट्रिंग, 0, या गलत है, तो यह वह मान लौटा देगा। उदाहरण के लिए: let name = ''; let user = name ?? 'John'; // user is '' यहां, एक खाली स्ट्रिंग है, इसलिए (पहला परिभाषित मान) मिलता है। name user name नुलिश कोलेसिंग ऑपरेटर हमें साफ़-सुथरे तरीके से डिफ़ॉल्ट मान प्रदान करने की अनुमति देता है। हम शून्य/अपरिभाषित मानों के लिए डिफ़ॉल्ट मान सेट कर सकते हैं, बिना झूठे मानों जैसे 0, खाली स्ट्रिंग, गलत आदि के बारे में चिंता किए बिना। उदाहरण के लिए, मान लें कि हमारे पास एक फ़ंक्शन है जो उपयोगकर्ता की आयु लौटाता है, लेकिन कभी-कभी आयु शून्य होती है: function getAge() { return age; // could be null } let userAge = getAge() || 30; // Uses OR, not ideal यहां, यदि 0, '', या गलत है, तो गलत तरीके से 30 होगी। age userAge नुलिश कोलेसिंग ऑपरेटर का उपयोग इसे ठीक करता है: let userAge = getAge() ?? 30; // Uses ?? अब, यदि शून्य या अपरिभाषित है तो केवल 30 होगी। 0 जैसे किसी अन्य मिथ्या मान का उपयोग किया जाएगा। age userAge तो संक्षेप में, जब आप शून्य/अपरिभाषित के लिए एक डिफ़ॉल्ट मान प्रदान करना चाहते हैं, लेकिन 0, खाली स्ट्रिंग्स, या गलत जैसे झूठे मानों के लिए नहीं, तो OR (||) के बजाय नलिश कोलेसिंग ऑपरेटर (??) का उपयोग करें। आपका कोड साफ़-सुथरा होगा और बग की संभावना कम होगी! अशक्त सहसंयोजन के बारे में सामान्य प्रश्न तो आपने जावास्क्रिप्ट में इस फैंसी नए न्यूलिश कोलेसिंग ऑपरेटर (??) के बारे में सुना है और आपके कुछ प्रश्न हैं। कोई चिंता नहीं, मैंने आपको कवर कर लिया है! नुलिश कोलेसिंग किस डेटा प्रकार के साथ काम करता है? शून्य सहसंयोजन जावास्क्रिप्ट में किसी भी डेटा प्रकार के साथ काम करता है, जिसमें शामिल हैं: संख्याएँ: 0 ?? 1 // रिटर्न 1 स्ट्रिंग्स: '' ?? 'हैलो' // रिटर्न 'हैलो' बूलियन्स: झूठा ?? सत्य // सत्य लौटाता है वस्तुएँ: {} ?? {नाम: 'जॉन'} // रिटर्न्स {नाम: 'जॉन'} सारणियाँ: [] ?? [1, 2, 3] // रिटर्न्स [1, 2, 3] और अधिक! में क्या अंतर है || (या और ?? (नलिश कोलेसिंग) संचालक? || (OR) यदि बायां ऑपरेंड गलत है (झूठा, 0, खाली स्ट्रिंग, शून्य, अपरिभाषित, NaN) तो ऑपरेटर दायां ऑपरेंड लौटा देगा। ?? (नलिश कोलेसिंग) ऑपरेटर केवल दायां ऑपरेंड लौटाएगा यदि बायां ऑपरेंड शून्य या अपरिभाषित है। तो मुख्य अंतर यह है ?? 0 और खाली स्ट्रिंग को वैध मान मानता है, जबकि || नहीं करता। मुझे कब उपयोग करना चाहिए ?? खत्म ||? उपयोग करें जब आप शून्य या अपरिभाषित के लिए एक डिफ़ॉल्ट मान प्रदान करना चाहते हैं, लेकिन 0 और खाली स्ट्रिंग को वैध मान मानते हैं। ?? प्रयोग करें || जब आप किसी "गलत" मान के लिए फ़ॉलबैक प्रदान करना चाहते हैं। आशा है कि यह नुलिश कोलेसिंग ऑपरेटर के बारे में आपके कुछ ज्वलंत प्रश्नों को स्पष्ट करने में मदद करेगा! अगर आपके पास कोई अन्य सवाल है तो मुझे बताएं। निष्कर्ष अब आप नलिश कोलेसिंग के बारे में सब कुछ जानते हैं और यह जावास्क्रिप्ट में कैसे काम करता है। बहुत आसान, है ना? यह छोटा ऑपरेटर संक्षिप्त तरीके से डिफ़ॉल्ट मान प्रदान करके आपका समय बचा सकता है और आपके कोड को साफ़-सुथरा बना सकता है। तो आगे बढ़ें और अपने दिल की संतुष्टि के लिए अशक्त मूल्यों को एकजुट करें! आप आधुनिक जावास्क्रिप्ट सुविधाओं में महारत हासिल करने की राह पर हैं। हैप्पी कोडिंग!