paint-brush
जावास्क्रिप्ट ऑब्जेक्ट: बुनियादी बातों से लेकर उन्नत तकनीकों तकद्वारा@smakss
3,723 रीडिंग
3,723 रीडिंग

जावास्क्रिप्ट ऑब्जेक्ट: बुनियादी बातों से लेकर उन्नत तकनीकों तक

द्वारा Max Kazemi17m2024/03/07
Read on Terminal Reader

बहुत लंबा; पढ़ने के लिए

जेएस ऑब्जेक्ट्स का अन्वेषण करें: प्रकारों को समझें, ऑब्जेक्ट बनाएं और प्रबंधित करें, समानता जांच, प्रोटोटाइप इनहेरिटेंस में गहराई से जाएं, और प्रमुख उपयोगिता कार्यों का उपयोग करें।
featured image - जावास्क्रिप्ट ऑब्जेक्ट: बुनियादी बातों से लेकर उन्नत तकनीकों तक
Max Kazemi HackerNoon profile picture
0-item
1-item
2-item

जावास्क्रिप्ट के मूल को समझना: आदिम और वस्तुएं

जावास्क्रिप्ट, विविध और लचीले डेटा प्रकारों की एक भाषा, मूल रूप से दो श्रेणियों में विभाजित है: प्रिमिटिव और ऑब्जेक्ट । यह अंतर सभी स्तरों पर डेवलपर्स के लिए समझना महत्वपूर्ण है, क्योंकि यह वह आधार बनाता है जिस पर जावास्क्रिप्ट संचालित होता है। आइए अपनी समझ को मजबूत करने के लिए इन अवधारणाओं पर दोबारा गौर करें।


आदिम मूल्य: मूल बातें

  • स्ट्रिंग : "hello" और "farewell" जैसे पाठ्य डेटा को उद्धरण चिह्नों के भीतर समाहित किया गया है, जो जावास्क्रिप्ट में पाठ्य हेरफेर के लिए आधारशिला के रूप में कार्य करता है।


  • संख्या : चाहे वह पूर्णांक ( -5 ) हो या दशमलव ( 3.14 ), संख्याएँ भाषा में गणितीय संक्रियाओं का आधार हैं।


  • BigInt : संख्या की सुरक्षित पूर्णांक सीमा से परे गणना के लिए, BigInt काम में आता है, जो बड़े पूर्णांकों पर सटीक अंकगणित को सक्षम बनाता है।


  • बूलियन : बूलियन प्रकार, अपने सही और गलत मूल्यों के साथ, तार्किक संचालन और नियंत्रण प्रवाह के लिए महत्वपूर्ण है।


  • अपरिभाषित : जिस चर को कोई मान नहीं दिया गया है, उसे स्वचालित रूप से अपरिभाषित का मान दिया जाता है, जो किसी विशिष्ट संदर्भ में मान की अनुपस्थिति को दर्शाता है।


  • प्रतीक : अद्वितीय संपत्ति कुंजियाँ सुनिश्चित करने के लिए पेश किया गया, प्रतीक अपरिवर्तनीय और अद्वितीय हैं, वस्तुओं में गैर-टकराव गुणों को जोड़ने के लिए आदर्श हैं।


  • शून्य : किसी वस्तु के मूल्य की जानबूझकर अनुपस्थिति को दर्शाता है। अपरिभाषित के विपरीत, शून्य को स्पष्ट रूप से 'कोई मूल्य नहीं' दर्शाने के लिए निर्दिष्ट किया गया है।


आदिम अपरिवर्तनीय हैं, जिसका अर्थ है कि एक बार बनने के बाद उनके मूल्यों को बदला नहीं जा सकता है। यह विशेषता अक्सर भ्रम की स्थिति पैदा करती है, खासकर जब हम किसी ऐसे वेरिएबल को गलती से मान लेते हैं जो एक आदिम मान रखता है।


यह समझना कि आदिम अपरिवर्तनीय हैं, जावास्क्रिप्ट व्यवहार के कई पहलुओं को स्पष्ट करने में मदद करता है, विशेष रूप से तुलना और असाइनमेंट संचालन में।


जावास्क्रिप्ट के माध्यम से हमारी यात्रा में, हालांकि हम इनमें से कुछ प्रकारों का सीधे उपयोग नहीं कर सकते हैं, उनकी भूमिकाओं को पहचानने और समझने से हमारा कोडिंग टूलकिट समृद्ध होता है, और अधिक परिष्कृत और कुशल कोड के लिए मार्ग प्रशस्त होता है।


आदिम के दायरे से परे, जावास्क्रिप्ट का ब्रह्मांड वस्तुओं पर हावी है। इस श्रेणी में डेटा संरचनाओं की एक विस्तृत श्रृंखला शामिल है, जिनमें से कुछ आपको आश्चर्यचकित कर सकती हैं, जैसे कि Arrays । मुख्य रूप से, हमारा सामना होता है:


  • ऑब्जेक्ट : मानक ऑब्जेक्ट के लिए {} या सरणियों के लिए [] द्वारा प्रस्तुत, ये संरचनाएं संबंधित डेटा और कार्यात्मकताओं को समूहीकृत करने के लिए रीढ़ की हड्डी हैं।


  • फ़ंक्शंस : अन्य के बीच x => x * 2 के रूप में व्यक्त, फ़ंक्शंस जावास्क्रिप्ट में प्रथम श्रेणी के नागरिक हैं, जो कोड को वेरिएबल्स को निर्दिष्ट करने, तर्क के रूप में पारित करने, या अन्य फ़ंक्शंस से वापस करने की अनुमति देते हैं।


वस्तुएँ मौलिक रूप से आदिम से भिन्न होती हैं; वे परिवर्तनशील हैं और हमारे कोड में सीधे हेरफेर किया जा सकता है। जावास्क्रिप्ट में हर चीज़ को एक वस्तु के रूप में देखना एक आम ग़लतफ़हमी है। आदिम मूल्यों के कुछ वस्तु-सदृश व्यवहारों के कारण यह आंशिक रूप से सत्य है। उदाहरण के लिए, अभिव्यक्ति "hi".toUpperCase() प्रश्न उठा सकती है: एक आदिम स्ट्रिंग में विधियाँ कैसे हो सकती हैं?


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


यह जावास्क्रिप्ट के डिज़ाइन का एक आकर्षक पहलू है, जो आदिम लोगों को वास्तव में ऑब्जेक्ट बने बिना ऑब्जेक्ट-जैसी विधियों से लाभ उठाने की अनुमति देता है। इस अंतर को समझना महत्वपूर्ण है क्योंकि हम जावास्क्रिप्ट की टाइपोलॉजी में गहराई से उतरते हैं।

जावास्क्रिप्ट के typeof ऑपरेटर और null के अनूठे मामले की खोज

जावास्क्रिप्ट में विभिन्न डेटा प्रकारों के बीच अंतर करना कभी-कभी जादू जैसा लग सकता है। typeof ऑपरेटर दर्ज करें, जो आपके जावास्क्रिप्ट टूलकिट में एक शक्तिशाली टूल है जो किसी दिए गए मान के प्रकार को प्रकट करता है। यहां बताया गया है कि यह व्यवहार में कैसे काम करता है:


 console.log(typeof(5)); // Outputs "number" console.log(typeof("hi")); // Outputs "string" console.log(typeof(undefined)); // Outputs "undefined" console.log(typeof({})); // Outputs "object" console.log(typeof([])); // Outputs "object" console.log(typeof(x => x * 2)); // Outputs "function"


हालाँकि, जावास्क्रिप्ट के दायरे में, सब कुछ वैसा नहीं दिखता जैसा दिखता है। उदाहरण के लिए, typeof ऑपरेटर के null के उपचार को लें। अपेक्षाओं के बावजूद, typeof null "object" लौटाता है, एक ऐसा परिणाम जो कई डेवलपर्स को हैरान कर देता है। यह व्यवहार इतना बड़ा बग नहीं है जितना कि भाषा की विचित्रता, जो जावास्क्रिप्ट के शुरुआती डिज़ाइन निर्णयों में निहित है।


मान null अर्थ किसी वस्तु मूल्य की जानबूझकर अनुपस्थिति का प्रतिनिधित्व करना है, फिर भी इसे एक वस्तु के रूप में वर्गीकृत किया typeof है। यह विचित्रता सर्वविदित है और पिछड़े संगतता पर चिंताओं के कारण जावास्क्रिप्ट के विकास के दौरान बनी रही है।


यह याद रखना महत्वपूर्ण है कि, undefined विपरीत, जो उन मूल्यों को दर्शाता है जिन्हें निर्दिष्ट नहीं किया गया है, null का उपयोग स्पष्ट रूप से 'कोई मूल्य नहीं' के जानबूझकर असाइनमेंट को दर्शाने के लिए किया जाता है। जबकि जावास्क्रिप्ट null और undefined के बीच उपयोग में अंतर को लागू नहीं करता है, आपके कोड के लिए एक सुसंगत दृष्टिकोण अपनाने से आपके इरादे को स्पष्ट करने में मदद मिल सकती है और पठनीयता और रखरखाव दोनों में सहायता मिल सकती है।

जावास्क्रिप्ट में अभिव्यक्ति को समझना: आपके कोड के साथ एक संवाद

जावास्क्रिप्ट की जीवंत दुनिया में, कोड लिखना प्रश्न पूछने के समान है, और भाषा उत्तर देती है। इन अंतःक्रियाओं को जिसे हम अभिव्यक्ति कहते हैं, उसके माध्यम से ग्रहण किया जाता है। जावास्क्रिप्ट में एक अभिव्यक्ति कोड की कोई भी वैध इकाई है जो किसी मान का समाधान करती है।


आइए एक सरल उदाहरण देखें:


 console.log(5 + 5); // Outputs 10


इस उदाहरण में, 5 + 5 एक अभिव्यक्ति है जिसका मूल्यांकन जावास्क्रिप्ट 10 के मान के साथ करता है।


अभिव्यक्तियाँ जावास्क्रिप्ट कोड के निर्माण खंड हैं, जो आपके कार्यक्रमों के भीतर गतिशील इंटरैक्शन और गणना को सक्षम करते हैं। वे उपरोक्त उदाहरण की तरह सरल या अधिक जटिल हो सकते हैं। वास्तव में, इंटरैक्टिव, गतिशील वेब एप्लिकेशन बनाने के लिए अभिव्यक्ति भाषा के साथ आपके संचार की सीधी रेखा है।

जावास्क्रिप्ट में ऑब्जेक्ट बनाना: आह्वान से कचरा संग्रहण तक

जबकि जावास्क्रिप्ट में आदिम डेटा प्रकार - जैसे स्ट्रिंग्स, संख्याएं और बूलियन - को पूर्वनिर्धारित संस्थाओं के रूप में अस्तित्व में बुलाया जाता है, वस्तुएं एक अलग सिद्धांत पर काम करती हैं। हर बार जब हम {} (घुंघराले ब्रेसिज़) का उपयोग करते हैं, तो हम केवल मौजूदा ब्लूप्रिंट का संदर्भ नहीं दे रहे हैं; हम एक बिल्कुल नई वस्तु अस्तित्व में ला रहे हैं। दो सरल वस्तुओं के निर्माण पर विचार करें:


 const cat = {}; const dog = {};


यहां, cat और dog अलग-अलग वस्तुएं हैं, प्रत्येक की स्मृति में अपना स्थान है। यह सिद्धांत केवल ऑब्जेक्ट शाब्दिक से आगे बढ़कर जावास्क्रिप्ट में सभी जटिल डेटा संरचनाओं को शामिल करता है, जिसमें सरणियाँ, दिनांक और फ़ंक्शन शामिल हैं।


हालाँकि इन संस्थाओं को बनाने के लिए विभिन्न विधियाँ हैं, ऑब्जेक्ट के लिए {} , सरणियों के लिए [] और तिथियों के लिए new Date() उपयोग ऑब्जेक्ट इंस्टेंस बनाने के लिए सबसे प्रत्यक्ष तरीकों में से एक है।


लेकिन इन वस्तुओं का क्या होता है जब उनकी आवश्यकता नहीं रह जाती है? क्या वे जावास्क्रिप्ट ब्रह्मांड में अनिश्चित काल तक बने रहेंगे? इसका उत्तर जावास्क्रिप्ट के कचरा संग्रहण तंत्र में निहित है - एक ऐसी प्रक्रिया जो उस मेमोरी को कुशलतापूर्वक साफ़ करती है जो अब उपयोग में नहीं है।


कचरा संग्रहण एक स्वचालित ऑपरेशन है, जिसका अर्थ है कि ऑब्जेक्ट नष्ट हो जाते हैं और उनकी आवंटित मेमोरी पुनः प्राप्त हो जाती है जब आपके कोड में उनका कोई संदर्भ नहीं होता है।

जावास्क्रिप्ट में मूल्यों की तुलना: सतह से परे समानता

जावास्क्रिप्ट में, मूल्यों की तुलना करना कभी-कभी एक भूलभुलैया को नेविगेट करने जैसा महसूस हो सकता है, जिसमें एक ही गंतव्य के लिए विभिन्न रास्ते होते हैं: समानता को समझना। मूल्यों की तुलना करने के तीन प्राथमिक तरीके हैं:


  1. सख्त समानता ( === ): समानता का यह रूप सबसे सटीक है, जो दो ऑपरेंड के मूल्य और प्रकार दोनों की जाँच करता है। यह पूछने के बराबर है, "क्या ये दोनों मान प्रकार और सामग्री दोनों में समान हैं?"


  2. ढीली समानता ( == ): सख्त समानता की तुलना में कम कठोर, ढीली समानता तुलना से पहले प्रकार की जबरदस्ती की अनुमति देती है। यह पूछने जैसा है, "क्या इन दोनों मूल्यों को समान माना जा सकता है यदि हम उनके प्रकारों को नजरअंदाज कर दें?"


  3. समान मूल्य समानता ( Object.is ): यह विधि सख्त समानता के समान है लेकिन कुछ महत्वपूर्ण अंतरों के साथ, विशेष रूप से यह विशेष जावास्क्रिप्ट मामलों को कैसे संभालती है।


आइए Object.is क्रियान्वित करते हुए देखें:


 console.log(Object.is(2, 2)); // true console.log(Object.is({}, {})); // false


Object.is({}, {}) गलत क्यों लौटाता है? क्योंकि प्रत्येक ऑब्जेक्ट शाब्दिक {} मेमोरी में एक अद्वितीय ऑब्जेक्ट बनाता है, जिससे Object.is उनकी संरचनात्मक समानता के बावजूद उन्हें अलग-अलग संस्थाओं के रूप में मानता है।

सख्त समानता की बारीकियों में गहराई से गोता लगाना

हालाँकि सख्त समानता सीधी है, इसमें विशिष्टताओं का अपना सेट है, विशेष रूप से कुछ जावास्क्रिप्ट मूल्यों के साथ:


  • NaN === NaN : आश्चर्यजनक रूप से, यह तुलना false परिणाम देती है। जावास्क्रिप्ट में, NaN (नॉट-ए-नंबर) को स्वयं के लिए असमान माना जाता है, एक दुर्लभ विशेषता जिसका उद्देश्य अपरिभाषित या गलत गणना के परिणाम को इंगित करना है।


  • -0 और 0 की तुलना करना: -0 === 0 और 0 === -0 दोनों true लौटते हैं, बावजूद इसके कि -0 और 0 जावास्क्रिप्ट की संख्या प्रणाली में अलग-अलग मान हैं। यह समानता शून्य के चिह्न को नज़रअंदाज़ करती है, केवल उसके परिमाण पर ध्यान केंद्रित करती है।

व्यवहारिक निहितार्थ

सटीक और बग-मुक्त जावास्क्रिप्ट कोड लिखने के लिए समानता जाँच में इन अंतरों को समझना सर्वोपरि है। जबकि === और == की अपनी भूमिकाएँ हैं, यह जानना कि कब Object.is नियोजित करना महत्वपूर्ण हो सकता है, विशेष रूप से NaN , 0 , और -0 से जुड़े किनारे के मामलों के लिए।


यह ज्ञान डेवलपर्स को समानता जांच के बारे में सूचित निर्णय लेने के लिए सशक्त बनाता है, जिससे यह सुनिश्चित होता है कि उनका कोड परिदृश्यों की एक विस्तृत श्रृंखला में अपेक्षित व्यवहार करता है।

जावास्क्रिप्ट में ऑब्जेक्ट गुणों और संदर्भों को नेविगेट करना

जब जावास्क्रिप्ट में ऑब्जेक्ट गुणों में हेरफेर करने की बात आती है, तो आपके पास दो प्राथमिक उपकरण होते हैं: डॉट नोटेशन और ब्रैकेट नोटेशन । दोनों विधियाँ किसी वस्तु की सामग्री तक पहुँचने और उसे संशोधित करने के लिए एक सीधा रास्ता प्रदान करती हैं। यहाँ एक त्वरित प्राइमर है:


  • डॉट नोटेशन : गुणों तक सीधे डॉट ऑपरेटर (जैसे, object.key ) के माध्यम से पहुंचें।


  • ब्रैकेट नोटेशन : संपत्ति का नाम निर्दिष्ट करने के लिए ब्रैकेट और एक स्ट्रिंग का उपयोग करें (उदाहरण के लिए, object['key'] )।


ये तकनीकें वस्तुओं के साथ बातचीत करने का आधार हैं। हालाँकि, समझने का एक महत्वपूर्ण पहलू यह है कि जावास्क्रिप्ट ऑब्जेक्ट संदर्भों को कैसे संभालता है। आदिम डेटा प्रकारों के विपरीत, जावास्क्रिप्ट में ऑब्जेक्ट संदर्भित प्रकार होते हैं, और इसका मतलब यह है कि जब आप किसी ऑब्जेक्ट में हेरफेर करते हैं, तो आप मेमोरी में उस ऑब्जेक्ट के स्थान के संदर्भ के साथ काम कर रहे हैं, न कि ऑब्जेक्ट की सीधी प्रतिलिपि के साथ।

एक वास्तविक दुनिया का चित्रण: कोड में सहयोगात्मक लेखन

इस अवधारणा को जीवन में लाने के लिए, आइए एक ऐसे परिदृश्य पर विचार करें जिसमें दो महत्वाकांक्षी लेखक, एमिली और थॉमस, एक उपन्यास पर सहयोग कर रहे हैं। वे अपनी कहानी के पात्रों और सेटिंग्स को संरचित करने के लिए जावास्क्रिप्ट ऑब्जेक्ट का उपयोग करने का निर्णय लेते हैं:


 const project = { title: "Adventures in Code", characters: { protagonist: { name: "Alex", traits: ["brave", "curious"] } }, setting: { location: "Virtual World", era: "future" } };


जैसे ही वे अपनी कहानी विकसित करते हैं, एमिली नायक से प्रेरित एक सहायक चरित्र का परिचय देती है लेकिन एक अनोखे मोड़ के साथ:


 const sidekick = project.characters.protagonist; sidekick.name = "Sam"; sidekick.traits.push("loyal");


इसके साथ ही, थॉमस ने अपने उपन्यास की पृष्ठभूमि का विस्तार करने का निर्णय लिया:


 const newSetting = project.setting; newSetting.location = "Cyber City"; newSetting.era = "2040";


पहली नज़र में, आपको आश्चर्य हो सकता है कि ये परिवर्तन मूल project ऑब्जेक्ट को कैसे प्रभावित करते हैं। यहाँ परिणाम है:


  • नायक का नाम अब "सैम" के रूप में प्रकट होता है, और उनके गुणों में "वफादारी" शामिल है। ऐसा इसलिए है क्योंकि sidekick कोई नई वस्तु नहीं है बल्कि project.characters.protagonist का संदर्भ है। sidekick संशोधित करने से मूल project ऑब्जेक्ट पर सीधा प्रभाव पड़ता है।


  • उपन्यास की पृष्ठभूमि वर्ष "2040" में "साइबर सिटी" के रूप में विकसित हुई है। पात्रों के समान, newSetting project.setting का एक संदर्भ है, जिसका अर्थ है कि newSetting में कोई भी परिवर्तन सीधे project.setting प्रभावित करता है।

सन्दर्भों की शक्ति को समझना

यह उदाहरण जावास्क्रिप्ट में एक महत्वपूर्ण अवधारणा को रेखांकित करता है: ऑब्जेक्ट के साथ काम करने का मतलब संदर्भों के साथ काम करना है, और जब आप किसी ऑब्जेक्ट को किसी वेरिएबल पर असाइन करते हैं, तो आप उस ऑब्जेक्ट का संदर्भ असाइन कर रहे होते हैं।


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


हमारी कहानी में, एमिली और थॉमस की सहयोगात्मक प्रक्रिया खूबसूरती से दर्शाती है कि कैसे ऑब्जेक्ट संदर्भ कोडिंग में रचनात्मक प्रयासों को पूरा कर सकते हैं, जिससे जटिल कथाओं के साझा, गतिशील विकास की अनुमति मिलती है - या, अधिक व्यावहारिक शब्दों में, आपके अनुप्रयोगों के भीतर जटिल डेटा संरचनाएं।

जावास्क्रिप्ट में ऑब्जेक्ट कॉपी करने में महारत हासिल करना: उथली बनाम गहरी प्रतियां

जावास्क्रिप्ट में ऑब्जेक्ट के साथ काम करते समय, संदर्भ प्रतिलिपि की प्रकृति के कारण प्रत्यक्ष असाइनमेंट से अनजाने संशोधन हो सकते हैं। ऑब्जेक्ट की एक प्रति बनाने से मूल ऑब्जेक्ट को प्रभावित किए बिना सुरक्षित हेरफेर की अनुमति मिलती है; इस तरह, हम अनजाने संशोधनों को कम कर देंगे।


आपकी ज़रूरतों और आपके पास मौजूद परिदृश्यों के आधार पर, आप उथली प्रतिलिपि और गहरी प्रतिलिपि के बीच चयन कर सकते हैं।

उथली प्रतिलिपि तकनीकें:

  • ऑब्जेक्ट.असाइन : यह विधि स्रोत से लक्ष्य ऑब्जेक्ट ( {} ) में गुणों की प्रतिलिपि बनाकर एक नई ऑब्जेक्ट उत्पन्न करती है। यह ध्यान रखना महत्वपूर्ण है कि Object.assign एक उथली प्रतिलिपि करता है, जिसका अर्थ है कि किसी भी नेस्टेड ऑब्जेक्ट या एरे को संदर्भ द्वारा कॉपी किया जाता है, न कि उनके मूल्य से।


     const original = { a: 1, b: { c: 2 } }; const copy = Object.assign({}, original); copy.bc = 3; // Affects both 'copy' and 'original'


  • स्प्रेड ऑपरेटर ( ... ): Object.assign के अनुरूप, स्प्रेड ऑपरेटर मूल ऑब्जेक्ट के गुणों को एक नई ऑब्जेक्ट में विस्तारित करता है, जिसके परिणामस्वरूप एक उथली प्रतिलिपि बनती है।


     const copyUsingSpread = { ...original }; copyUsingSpread.bc = 4; // Also affects the 'original' object

डीप कॉपी विधियाँ:

  • JSON.parse और JSON.stringify : यह दृष्टिकोण ऑब्जेक्ट को JSON स्ट्रिंग में क्रमबद्ध करता है, और फिर इसे एक नए ऑब्जेक्ट में वापस पार्स करता है। यह प्रभावी रूप से एक गहरी प्रतिलिपि बनाता है लेकिन फ़ंक्शंस, दिनांक ऑब्जेक्ट, अपरिभाषित और अन्य गैर-क्रमबद्ध मानों को संभाल नहीं सकता है।


     const deepCopy = JSON.parse(JSON.stringify(original)); deepCopy.bc = 5; // Does not affect the 'original' object


  • पुस्तकालय : अधिक जटिल परिदृश्यों के लिए, लॉडैश जैसे पुस्तकालय फ़ंक्शन प्रदान करते हैं (उदाहरण के लिए, _.cloneDeep() ) जो वस्तुओं को गहराई से क्लोन कर सकते हैं, जिसमें JSON विधियों की तुलना में विभिन्न डेटा प्रकारों को अधिक प्रभावी ढंग से संभालना भी शामिल है।

व्यावहारिक अनुप्रयोग

आइए हमारे सहयोगी लेखन परियोजना उदाहरण पर दोबारा गौर करें:


 const project = { title: "Adventures in Code", characters: { protagonist: { name: "Alex", traits: ["brave", "curious"] } }, setting: { location: "Virtual World", era: "future" } };


मूल को प्रभावित किए बिना प्रोजेक्ट को संशोधित करने के लिए:

  • डीप कॉपी के लिए : नया कैरेक्टर सुरक्षित रूप से जोड़ने या सेटिंग बदलने के लिए JSON.parse(JSON.stringify(project)) का उपयोग करें।


  • उथली प्रतिलिपि के लिए : शीर्ष-स्तरीय परिवर्तनों के लिए Object.assign या स्प्रेड ऑपरेटर का उपयोग करें जहां नेस्टेड संरचनाएं चिंता का विषय नहीं हैं।


उथली और गहरी प्रतिलिपि के बीच चयन करना वस्तु की जटिलता और आपके हेरफेर की विशिष्ट आवश्यकताओं पर निर्भर करता है। उथली प्रतियां सरल वस्तुओं के लिए तेज और अधिक उपयुक्त होती हैं, जबकि नेस्टेड संरचनाओं वाली वस्तुओं के लिए गहरी प्रतियां आवश्यक होती हैं, जिससे यह सुनिश्चित होता है कि मूल वस्तु अछूती रहे।


इन मुकाबला तकनीकों को समझने और लागू करने से, आप जावास्क्रिप्ट की संदर्भ-आधारित प्रणाली को विश्वास के साथ नेविगेट कर सकते हैं, यह सुनिश्चित करते हुए कि आपके डेटा हेरफेर सटीक और जानबूझकर हैं।

प्रोटोटाइप: जावास्क्रिप्ट में विरासत के छिपे हुए धागे

जिस प्रकार किसी उपन्यास के पात्रों को अपने पूर्वजों से गुण विरासत में मिलते हैं, उसी प्रकार जावास्क्रिप्ट में वस्तुओं को उनके प्रोटोटाइप से गुण और तरीके विरासत में मिलते हैं। यह अवधारणा कहानी कहने के उस शिल्प को प्रतिबिंबित करती है जिसे एमिली और थॉमस अपने उपन्यास "एडवेंचर्स इन कोड" में खोज रहे हैं।


प्रोटोटाइप के बारे में हमारी समझ को गहरा करने के लिए, आइए उनकी कहानी को जारी रखें, एक नया कैरेक्टर आर्क पेश करें जो जावास्क्रिप्ट में इनहेरिटेंस मॉडल को प्रतिबिंबित करता है।


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


 // The Ancient Coder, known for his profound wisdom const ancientCoder = { wisdom: 100 }; // Coder Leo, a young scribe in training const coderLeo = { __proto__: ancientCoder, age: 15 };


इस कथा में, कोडर लियो "द प्रोटोटाइप चेन" नामक जादुई विरासत के माध्यम से सीधे प्राचीन कोडर से जुड़ा हुआ है। यह कनेक्शन लियो को अपने पूर्वज की बुद्धिमत्ता का लाभ उठाने की अनुमति देता है।


 console.log(coderLeo.wisdom); // 100


प्रोटोटाइप श्रृंखला के लिए धन्यवाद, कोडर लियो अपनी युवावस्था के बावजूद प्राचीन कोडर के ज्ञान तक पहुंच सकता है। लेकिन तब क्या होता है जब उन्हें किसी ऐसी चुनौती या विशेषता का सामना करना पड़ता है जो प्राचीन कोडर के पास नहीं थी?


 console.log(coderLeo.courage); // undefined


यह स्थिति जावास्क्रिप्ट के प्रोटोटाइप सिस्टम के एक प्रमुख सिद्धांत को दर्शाती है: यदि ऑब्जेक्ट पर कोई संपत्ति नहीं मिलती है, तो जावास्क्रिप्ट इसे खोजने के लिए प्रोटोटाइप श्रृंखला को देखेगा। यदि संपत्ति अभी भी नहीं मिली है, तो undefined लौटा दिया जाता है, जो उस विशेषता की अनुपस्थिति को दर्शाता है।


अपनी कथा को आगे बढ़ाने के लिए, एमिली और थॉमस ने पता लगाया कि वंशजों में अद्वितीय लक्षण कैसे जोड़े जा सकते हैं, जो उन्हें उनके पूर्वजों से अलग करते हैं:


 // Introducing a unique trait to Coder Leo coderLeo.courage = 50; console.log(ancientCoder.courage); // undefined console.log(coderLeo.courage); // 50


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


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

अनावरण जादू: प्रोटोटाइप और अंतर्निहित विधियों की शक्ति

जैसे ही एमिली और थॉमस अपने उपन्यास, "एडवेंचर्स इन कोड" में गहराई से उतरे, उन्हें एक रहस्यमय अध्याय मिला: प्रोटोज़ का प्राचीन टोम। उन्होंने पाया कि यह पुस्तक सिर्फ एक प्लॉट डिवाइस नहीं है, बल्कि जावास्क्रिप्ट में प्रोटोटाइप और अंतर्निहित तरीकों को समझने के लिए एक रूपक है - ऐसी अवधारणाएं जो उनकी कहानी की दुनिया और कोडिंग की उनकी समझ में जादू की एक परत जोड़ देंगी।


स्क्रिप्ट्सविले में, उनके उपन्यास की काल्पनिक सेटिंग, प्रत्येक पात्र और वस्तु टोम ऑफ प्रोटोस की क्षमताओं से ओत-प्रोत है। यह जादुई पुस्तक सभी ज्ञान और कौशल का स्रोत है, जो जावास्क्रिप्ट में प्रोटोटाइप के समान है जिससे वस्तुओं को गुण और विधियाँ प्राप्त होती हैं।


 // A seemingly ordinary quill in Scriptsville const quill = {};


एमिली, अपने चरित्र ऐली के माध्यम से, इस क्विल की खोज करती है, लेकिन इसे एक जादुई धागे के माध्यम से प्रोटोज़ के टोम से जुड़ा हुआ पाती है - जो जावास्क्रिप्ट ऑब्जेक्ट्स में __proto__ प्रॉपर्टी का सीधा सादृश्य है, जो उन्हें उनके प्रोटोटाइप से जोड़ता है।


 console.log(quill.__proto__); // Reveals the Tome's ancient scripts!


यह रहस्योद्घाटन ऐली को टोम के ज्ञान तक पहुंचने की अनुमति देता है, जिसमें ऑब्जेक्ट प्रोटोटाइप से विरासत में मिली जावास्क्रिप्ट की अंतर्निहित विधियों का प्रदर्शन करते हुए hasOwnProperty और toString को लागू करने की क्षमता शामिल है।


कथा में थॉमस के चरित्र, मास्टर डोनोवन का परिचय दिया गया है, जो एक प्रसिद्ध बेकर है जो अपने मंत्रमुग्ध डोनट्स के लिए जाना जाता है। अपने पाककला उपहार को साझा करने की कोशिश में, डोनोवन ने एक जादू तैयार किया, जो जावास्क्रिप्ट में एक कंस्ट्रक्टर फ़ंक्शन को परिभाषित करने जैसा है:


 function EnchantedDoughnut() { this.flavor = "magic"; } EnchantedDoughnut.prototype.eat = function() { console.log("Tastes like enchantment!"); };


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


जैसे-जैसे स्क्रिप्ट्सविले विकसित होता है, वैसे-वैसे इसका जादू भी विकसित होता है, जो प्राचीन मंत्रों से वर्ग वाक्यविन्यास की आधुनिक कला में परिवर्तित होता है। एमिली और थॉमस ने डोनोवन के शिल्प को नए वाक्यविन्यास के साथ फिर से कल्पना की, जिससे उनका जादू अधिक सुलभ हो गया और जावास्क्रिप्ट में समकालीन प्रथाओं के साथ संरेखित हो गया:


 class ModernEnchantedDoughnut { constructor() { this.flavor = "modern magic"; } eat() { console.log("Tastes like modern enchantment!"); } }


यह परिवर्तन न केवल डोनोवन की बेकिंग कला को अद्यतन करता है बल्कि अंतर्निहित प्रोटोटाइप-आधारित विरासत को संरक्षित करते हुए क्लास सिंटैक्स की सुंदरता और दक्षता को उजागर करते हुए जावास्क्रिप्ट के विकास को भी प्रतिबिंबित करता है।

हमने एमिली और थॉमस से क्या सीखा?

"एडवेंचर्स इन कोड" के निर्माण के माध्यम से एमिली और थॉमस की यात्रा प्रोटोटाइप, अंतर्निहित तरीकों और जावास्क्रिप्ट के विकास को समझने के लिए एक आकर्षक रूपक बन जाती है।


अपने पात्रों और कहानियों के माध्यम से, वे जटिल अवधारणाओं को इस तरह से उजागर करते हैं जो आकर्षक और गहन है, यह दिखाते हुए कि प्रत्येक वस्तु और चरित्र, प्रत्येक जावास्क्रिप्ट ऑब्जेक्ट की तरह, विरासत और नवीनता के एक बड़े, परस्पर जुड़े टेपेस्ट्री का हिस्सा है।


उनकी कहानी कहानी कहने और प्रोग्रामिंग दोनों में एक बुनियादी सच्चाई को रेखांकित करती है: वर्तमान में महारत हासिल करने और भविष्य के लिए नवाचार करने के लिए अतीत को समझना आवश्यक है।


स्क्रिप्ट्सविले की जादुई दुनिया, अपने प्राचीन कब्रों, मंत्रमुग्ध डोनट्स और आधुनिक जादू के साथ, जावास्क्रिप्ट के प्रोटोटाइप सिस्टम की गहराई और विरासत की शक्ति की खोज के लिए एक ज्वलंत पृष्ठभूमि के रूप में कार्य करती है।

स्क्रिप्ट्सविले की जादुई उपयोगिताएँ: करामाती वस्तुएँ और सद्भाव सुनिश्चित करना

जैसे-जैसे एमिली और थॉमस अपने उपन्यास एडवेंचर्स इन कोड में गहराई से उतरे, उन्हें पात्रों, सेटिंग्स और जादुई वस्तुओं से भरी जटिल दुनिया को प्रबंधित करने के तरीके की आवश्यकता का पता चला।


उन्होंने एली की ओर रुख किया, जो स्क्रिप्ट्सविले की एक बुद्धिमान लेखिका थी, जो वस्तुओं को मंत्रमुग्ध करने और पूरे देश में सद्भाव सुनिश्चित करने में अपनी विशेषज्ञता के लिए जानी जाती थी।

पथों का आकर्षण: निहित वास्तविकताओं को सुनिश्चित करना

ऐली ने उनके साथ एक जादुई सूत्र, ensureObjectPath साझा किया, जो उनकी दुनिया के भीतर नेस्टेड क्षेत्रों के अस्तित्व को सुनिश्चित करने में सक्षम है:


 function ensureObjectPath({obj, path}) { path.split('.').reduce((acc, part) => { if (!acc[part]) acc[part] = {}; return acc[part]; }, obj); return obj; } // Ensuring the path to a hidden forest in their novel const world = {}; ensureObjectPath({obj: world, path: 'hidden.forest.clearing'}); console.log(world); // Outputs: { hidden: { forest: { clearing: {} } } }


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

आवश्यक तत्वों का स्क्रॉल: पात्रों की अनिवार्यताओं को सुनिश्चित करना

इसके अलावा, ऐली ने उन्हें एक और मंत्र, checkForRequiredKeys से परिचित कराया, जो यह सुनिश्चित करने के लिए डिज़ाइन किया गया था कि प्रत्येक पात्र के पास उनकी यात्रा के लिए आवश्यक आवश्यक गुण हों:


 const REQUIRED_KEYS = ['age', 'address', 'gender']; function checkForRequiredKeys(obj) { REQUIRED_KEYS.forEach(key => { if (!Object.hasOwn(obj, key)) { obj[key] = {}; } }); } // Ensuring every character has the essential attributes const character = { name: "Ellie" }; checkForRequiredKeys(character); console.log(character); // Outputs: { name: "Ellie", age: {}, address: {}, gender: {} }


इस जादू ने एमिली और थॉमस को अपने पात्रों में जटिलता बुनने की अनुमति दी, यह सुनिश्चित करते हुए कि किसी भी विवरण को नजरअंदाज नहीं किया गया, चाहे उनकी कथाएँ कितनी भी जटिल क्यों न हों।

स्क्रिप्ट्सविले की गूँज: मंत्रमुग्धता से ज्ञानोदय तक

जैसे-जैसे उनकी कहानी सामने आई, ऐली द्वारा साझा किए गए जादू ने न केवल "एडवेंचर्स इन कोड" को समृद्ध किया, बल्कि जावास्क्रिप्ट में ऑब्जेक्ट हेरफेर और संरचना के अंतर्निहित सिद्धांतों पर भी प्रकाश डाला।


जिस तरह नेस्टेड वास्तविकताओं के निर्माण के लिए ensureObjectPath मंत्र की अनुमति दी गई है, जावास्क्रिप्ट डेवलपर्स अपने अनुप्रयोगों के भीतर डेटा की संरचना करने के लिए समान शक्ति का उपयोग करते हैं।


इसी तरह, checkForRequiredKeys वर्तनी डेटा अखंडता सुनिश्चित करने के लिए आवश्यक रक्षात्मक प्रोग्रामिंग प्रथाओं को प्रतिबिंबित करती है।

निष्कर्ष

स्क्रिप्ट्सविले, एमिली, थॉमस, ऐली और जादुई प्राणियों की एक श्रृंखला के जादुई क्षेत्रों के माध्यम से हमारी भटकन में हमारे साथी रहे हैं, जो कि भूमि के रूप में मनोरम तरीके से जावास्क्रिप्ट के रहस्यों को उजागर कर रहे हैं।


रोमांच और खोज की कहानियों के माध्यम से, हमने जावास्क्रिप्ट के मूल में गहराई से प्रवेश किया है, इसके सरलतम वाक्यविन्यास से लेकर इसकी सतह के नीचे चलने वाले जटिल इंजनों तक।


यह किसी अन्य यात्रा से भिन्न है, जहां कहानी कहने का जादू प्रोग्रामिंग के तर्क के साथ विलीन हो जाता है, जो जावास्क्रिप्ट के ब्रह्मांड के स्तरित चमत्कारों को प्रकट करता है।


  • आदिम बनाम वस्तु प्रकार : हमने जावास्क्रिप्ट के आदिम और वस्तु प्रकारों के बीच अंतर करके शुरुआत की, जिससे पता चला कि ये बिल्डिंग ब्लॉक भाषा की नींव कैसे बनाते हैं। हमारे पात्रों की खोज के माध्यम से, हमने आदिम की अपरिवर्तनीय प्रकृति और वस्तुओं की गतिशील, संदर्भ-आधारित प्रकृति को समझा।


  • ऑब्जेक्ट बनाना और तुलना करना : हमने ऑब्जेक्ट निर्माण, मूल्यों की तुलना और जावास्क्रिप्ट में समानता की बारीकियों के बारे में सीखा। स्क्रिप्ट्सविले में जादुई कलाकृतियों और मंत्रों ने सख्त समानता ( === ), ढीली समानता ( == ), और सूक्ष्म तुलनाओं के लिए Object.is के उपयोग को समझने के महत्व पर प्रकाश डाला।


  • ऑब्जेक्ट गुण और प्रोटोटाइप : ऑब्जेक्ट गुणों में गहराई से जाने पर, हमने ऑब्जेक्ट इनहेरिटेंस में प्रोटोटाइप की महत्वपूर्ण भूमिका के साथ-साथ गुणों तक पहुंचने और संशोधित करने के लिए डॉट और ब्रैकेट नोटेशन की शक्ति की खोज की।


    स्क्रिप्ट्सविले में विरासत के तारों और मंत्रमुग्ध स्क्रॉल की कहानियों ने प्रोटोटाइप श्रृंखला को जीवंत कर दिया, जिसमें दिखाया गया कि कैसे वस्तुएं विरासत में मिलती हैं और गुणों को ओवरराइड करती हैं।


  • वस्तुओं के लिए उपयोगिता कार्य : अंत में, हमने उपयोगिता कार्यों का पता लगाया जो वस्तु संरचनाओं में हेरफेर करते हैं और डेटा अखंडता सुनिश्चित करते हैं। ऐली द्वारा साझा किए गए जादुई सूत्र, जैसे कि ensureObjectPath और checkForRequiredKeys , नेस्टेड वस्तुओं के साथ काम करने और आवश्यक गुणों की उपस्थिति सुनिश्चित करने के लिए व्यावहारिक तकनीकों का प्रदर्शन किया।


स्क्रिप्ट्सविले की कथा के लेंस के माध्यम से, हमने देखा है कि कैसे जावास्क्रिप्ट की विशेषताएं जादुई और तार्किक दोनों हो सकती हैं, जो डेवलपर्स को रचनात्मकता और समस्या-समाधान के लिए एक विशाल खेल का मैदान प्रदान करती हैं।


स्क्रिप्ट्सविले की मनमोहक कहानियाँ सिर्फ कहानियों से कहीं अधिक हैं; वे प्रोग्रामिंग की कलात्मकता के रूपक हैं, जो हमारी डिजिटल दुनिया को कुशलता से तैयार करने के लिए जावास्क्रिप्ट के मूल सिद्धांतों को समझने के महत्व पर प्रकाश डालते हैं।


जैसे ही हम इस यात्रा पर पुस्तक बंद करते हैं, याद रखें कि रोमांच यहीं समाप्त नहीं होता है। हमारे द्वारा खोजी गई प्रत्येक अवधारणा जावास्क्रिप्ट की गहरी समझ और महारत हासिल करने की दिशा में एक कदम है।


जिस तरह एमिली और थॉमस ने "एडवेंचर्स इन कोड" की अपनी कहानी गढ़ी, उसी तरह आप भी प्रोग्रामिंग के असीमित ब्रह्मांड के भीतर अपनी कथाएं, मंत्रमुग्ध वस्तुएं और जादुई क्षेत्र गढ़ सकते हैं।