how does object behave here in javascript? -


इस सवाल का पहले से ही एक उत्तर है: < / P>

  • 6 जवाब

मुझे पता है कि हम कर सकते हैं ' टी सीधे एक वस्तु की तुलना करें कि अन्य के बराबर है {} == {} झूठी बदलेगी।

  var b = {}; बी === ऑब्जेक्ट (बी); // सच ब === ऑब्जेक्ट ({}); // झूठी  

हालांकि, ऊपर के कोड मुझे भ्रमित करते हैं, क्यों b === वस्तु ({}) वापसी झूठी? कोई यह बता सकता है?

यह वास्तव में

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

जैसा कि आप पहले से जानते हैं, दो ऑब्जेक्ट समान नहीं हैं

  {} == {} // false  

लेकिन जब आप किसी ऑब्जेक्ट को ऑब्जेक्ट कन्स्ट्रक्टर में पास करते हैं, तो वह सटीक एक ही ऑब्जेक्ट देता है, न कि एक नया।

  var b = {}; बी === ऑब्जेक्ट (बी); // सच  

यहां आप ऑब्जेक्ट कन्स्ट्रक्टर को उसी ऑब्जेक्ट को पास करते हैं जो आप फिर से तुलना कर रहे हैं, और ऑब्जेक्ट कन्स्ट्रक्टर उस ऑब्जेक्ट को वापस करेगा, और ऑब्जेक्ट की तुलना करके स्वयं के विरुद्ध रिटर्न करेगा सच । दूसरे शब्दों में, उपर्युक्त b === b के समान है।
इस पर चल रहा है

  b === वस्तु ({}); // गलत  

यहां आप एक खाली नई ऑब्जेक्ट में गुजर रहे हैं, उस ऑब्जेक्ट को लौटा दिया जाएगा, लेकिन यह b जैसा ही ऑब्जेक्ट नहीं होगा, और दो अलग-अलग ऑब्जेक्ट कभी भी बराबर नहीं होते हैं, इसलिए false


Comments

Popular posts from this blog

java - org.apache.http.ProtocolException: Target host is not specified -

c# - Chart control: Design messed Up after clearing and re-adding Y-Values -

ruby on rails - Apipie interferes with proper error codes -