ईएस 6 - ऑब्जेक्ट्स

जावास्क्रिप्ट डेटा प्रकार का विस्तार करता है। जावास्क्रिप्ट ऑब्जेक्ट कस्टम डेटा प्रकारों को परिभाषित करने का एक शानदार तरीका है।

एक objectएक उदाहरण है जिसमें मुख्य मूल्य जोड़े का एक सेट होता है। आदिम डेटा प्रकारों के विपरीत, ऑब्जेक्ट कई या जटिल मूल्यों का प्रतिनिधित्व कर सकते हैं और अपने जीवन काल में बदल सकते हैं। मान स्केलर मान या फ़ंक्शन या अन्य ऑब्जेक्ट्स की सरणी भी हो सकते हैं।

किसी वस्तु को परिभाषित करने के लिए वाक्यात्मक रूपांतरों की चर्चा आगे की गई है।

ऑब्जेक्ट शुरुआती

आदिम प्रकारों की तरह, वस्तुओं का शाब्दिक वाक्य-विन्यास होता है: curly bracesv({तथा})। किसी वस्तु को परिभाषित करने के लिए निम्नलिखित सिंटैक्स है।

var identifier = {
   Key1:value, Key2: function () { 
      //functions 
   }, 
   Key3: [“content1”,” content2”] 
}

किसी वस्तु की सामग्री को कहा जाता है properties (या सदस्य), और गुण एक से मिलकर होते हैं name (या कुंजी) और value। संपत्ति के नाम तार या प्रतीक होने चाहिए, और मान किसी भी प्रकार (अन्य वस्तुओं सहित) हो सकते हैं।

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

ऑब्जेक्ट गुण तक पहुँचने के लिए सिंटैक्स निम्नलिखित है।

objectName.propertyName

उदाहरण: ऑब्जेक्ट इनिशियलाइज़र

var person = { 
   firstname:"Tom", 
   lastname:"Hanks", 
   func:function(){return "Hello!!"},    
}; 
//access the object values 
console.log(person.firstname)   
console.log(person.lastname) 
console.log(person.func())

उपरोक्त उदाहरण, एक वस्तु को परिभाषित करता है। वस्तु में तीन गुण होते हैं। तीसरी संपत्ति एक फ़ंक्शन को संदर्भित करती है।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Tom 
Hanks 
Hello!!

ES6 में, एक प्रॉपर्टी वैल्यू असाइन करना जो प्रॉपर्टी के नाम से मेल खाता है, आप प्रॉपर्टी वैल्यू को छोड़ सकते हैं।

उदाहरण

var foo = 'bar' 
var baz = { foo } 
console.log(baz.foo)

उपरोक्त कोड स्निपेट किसी वस्तु को परिभाषित करता है baz। वस्तु का एक गुण होता हैfoo। संपत्ति का मूल्य यहां छोड़ा गया है क्योंकि ES6 स्पष्ट रूप से वस्तु के प्रमुख फू के लिए चर फू के मूल्य को निर्दिष्ट करता है।

निम्नलिखित कोड के बराबर ES5 है।

var foo = 'bar' 
var baz = { foo:foo } 
console.log(baz.foo)

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

bar

इस शॉर्टहैंड सिंटैक्स के साथ, जेएस इंजन एक ही नाम के साथ एक चर के लिए युक्त दायरे में दिखता है। यदि यह पाया जाता है, कि चर का मान संपत्ति को सौंपा गया है। यदि यह नहीं पाया जाता है, तो एक संदर्भ त्रुटि फेंक दी जाती है।

ऑब्जेक्ट () कंस्ट्रक्टर

जावास्क्रिप्ट एक विशेष रचनाकार फ़ंक्शन प्रदान करता है जिसे कहा जाता है Object()वस्तु बनाने के लिए। नए ऑपरेटर का उपयोग किसी वस्तु का उदाहरण बनाने के लिए किया जाता है। ऑब्जेक्ट बनाने के लिए, नए ऑपरेटर का निर्माण विधि द्वारा किया जाता है।

किसी वस्तु को परिभाषित करने के लिए निम्नलिखित सिंटैक्स है।

var obj_name = new Object(); 
obj_name.property = value;    
OR             
obj_name["key"] = value

निम्नलिखित एक संपत्ति तक पहुँचने के लिए वाक्यविन्यास है।

Object_name.property_key                    
OR              
Object_name["property_key"]

उदाहरण

var myCar = new Object(); 
myCar.make = "Ford"; //define an object 
myCar.model = "Mustang"; 
myCar.year = 1987;  

console.log(myCar["make"]) //access the object property 
console.log(myCar["model"]) 
console.log(myCar["year"])

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Ford 
Mustang 
1987

किसी वस्तु के अनिर्दिष्ट गुण अपरिभाषित होते हैं।

उदाहरण

var myCar = new Object(); 
myCar.make = "Ford"; 
console.log(myCar["model"])

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

undefined

Note- एक ऑब्जेक्ट प्रॉपर्टी का नाम किसी भी मान्य जावास्क्रिप्ट स्ट्रिंग, या कुछ भी हो सकता है जिसे रिक्त स्ट्रिंग सहित स्ट्रिंग में परिवर्तित किया जा सकता है। हालांकि, कोई भी संपत्ति का नाम जो मान्य जावास्क्रिप्ट पहचानकर्ता नहीं है (उदाहरण के लिए, एक संपत्ति नाम जिसमें एक स्थान या एक हाइफ़न है, या जो एक संख्या से शुरू होता है) केवल स्क्वायर ब्रैकेट नोटेशन का उपयोग करके पहुँचा जा सकता है।

एक चर में संग्रहीत स्ट्रिंग मान का उपयोग करके भी गुण तक पहुँचा जा सकता है। दूसरे शब्दों में, ऑब्जेक्ट की संपत्ति कुंजी एक गतिशील मूल्य हो सकती है। उदाहरण के लिए: एक चर। उक्त अवधारणा निम्नलिखित उदाहरण में सचित्र है।

उदाहरण

var myCar = new Object()  
var propertyName = "make"; 
myCar[propertyName] = "Ford"; 
console.log(myCar.make)

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Ford

कंस्ट्रक्टर फंक्शन

निम्नलिखित दो चरणों का उपयोग करके एक वस्तु बनाई जा सकती है -

Step 1 - कंस्ट्रक्टर फ़ंक्शन लिखकर ऑब्जेक्ट प्रकार को परिभाषित करें।

निम्नलिखित के लिए सिंटैक्स है।

function function_name() { 
   this.property_name = value 
}

‘this’ कीवर्ड उपयोग में वर्तमान ऑब्जेक्ट को संदर्भित करता है और ऑब्जेक्ट की संपत्ति को परिभाषित करता है।

Step 2 - नए सिंटैक्स के साथ ऑब्जेक्ट का एक उदाहरण बनाएं।

var Object_name= new function_name() 
//Access the property value  

Object_name.property_name

नया कीवर्ड फ़ंक्शन कंस्ट्रक्टर को आमंत्रित करता है और फ़ंक्शन की प्रॉपर्टी कीज़ को इनिशियलाइज़ करता है।

Example − Using a Function Constructor

function Car() { 
   this.make = "Ford" 
   this.model = "F123" 
}  
var obj = new Car() 
console.log(obj.make) 
console.log(obj.model)

उपरोक्त उदाहरण किसी ऑब्जेक्ट को परिभाषित करने के लिए फ़ंक्शन कंस्ट्रक्टर का उपयोग करता है।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Ford 
F123

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

function Car() { 
   this.make = "Ford" 
} 
var obj = new Car() 
obj.model = "F123" 
console.log(obj.make) 
console.log(obj.model)

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Ford 
F123

Object.create विधि

वस्तुओं का उपयोग करके भी बनाया जा सकता है Object.create()तरीका। यह आपको एक निर्माता फ़ंक्शन को परिभाषित किए बिना, इच्छित ऑब्जेक्ट के लिए प्रोटोटाइप बनाने की अनुमति देता है।

उदाहरण

var roles = { 
   type: "Admin", // Default value of properties 
   displayType : function() {  
      // Method which will display type of role 
      console.log(this.type); 
   } 
}  
// Create new role type called super_role 
var super_role = Object.create(roles); 
super_role.displayType(); // Output:Admin  

// Create new role type called Guest 
var guest_role = Object.create(roles); 
guest_role.type = "Guest"; 
guest_role.displayType(); // Output:Guest

उपरोक्त उदाहरण एक ऑब्जेक्ट को परिभाषित करता है और गुण के लिए डिफ़ॉल्ट मान सेट करता है। दो नए उदाहरण बनाए जाते हैं जो ऑब्जेक्ट के लिए डिफ़ॉल्ट गुण मान को ओवरराइड करते हैं।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Admin 
Guest

Object.assign () फ़ंक्शन

Object.assign()विधि का उपयोग एक या एक से अधिक स्रोत वस्तुओं से लक्ष्य वस्तु तक सभी गणना करने योग्य गुणों के मूल्यों को कॉपी करने के लिए किया जाता है। यह लक्ष्य वस्तु को लौटा देगा।

निम्नलिखित के लिए सिंटैक्स है।

Object.assign(target, ...sources)

Example − Cloning an Object

"use strict" 
var det = { name:"Tom", ID:"E1001" }; 
var copy = Object.assign({}, det); 
console.log(copy);  
for (let val in copy) { 
   console.log(copy[val]) 
}

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Tom 
E1001

Example − Merging Objects

var o1 = { a: 10 }; 
var o2 = { b: 20 }; 
var o3 = { c: 30 }; 
var obj = Object.assign(o1, o2, o3); 
console.log(obj);  
console.log(o1);

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

{ a: 10, b: 20, c: 30 } 
{ a: 10, b: 20, c: 30 }

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

var o1 = { a: 10 }; 
var obj = Object.assign(o1); 
obj.a++ 
console.log("Value of 'a' in the Merged object after increment  ") 
console.log(obj.a);  
console.log("value of 'a' in the Original Object after increment ") 
console.log(o1.a);

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Value of 'a' in the Merged object after increment 
11  
value of 'a' in the Original Object after increment 
11

गुण हटाना

आप डिलीट ऑपरेटर का उपयोग करके किसी प्रॉपर्टी को हटा सकते हैं। निम्न कोड दिखाता है कि किसी संपत्ति को कैसे निकालना है।

उदाहरण

// Creates a new object, myobj, with two properties, a and b. 
var myobj = new Object; 
myobj.a = 5; 
myobj.b = 12; 

// Removes the ‘a’ property 
delete myobj.a; 
console.log ("a" in myobj) // yields "false"

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

false

कोड स्निपेट ऑब्जेक्ट से संपत्ति को हटा देता है। ऑपरेटर में ऑब्जेक्ट के रूप में गुण नहीं मिलने पर उदाहरण गलत साबित होता है।

वस्तुओं की तुलना करना

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

Example 1 − Different Object References

var val1 = {name: "Tom"}; 
var val2 = {name: "Tom"}; 
console.log(val1 == val2)  // return false 
console.log(val1 === val2)  // return false

उपरोक्त उदाहरण में, val1 तथा val2दो अलग-अलग ऑब्जेक्ट हैं जो दो अलग-अलग मेमोरी एड्रेस को संदर्भित करते हैं। इसलिए समानता के लिए तुलना करने पर, ऑपरेटर गलत वापस आ जाएगा।

Example 2 − Single Object Reference

var val1 = {name: "Tom"}; 
var val2 = val1  

console.log(val1 == val2) // return true 
console.log(val1 === val2) // return true

उपरोक्त उदाहरण में, val1 में सामग्री को val2 को सौंपा गया है, अर्थात val1 में गुणों के संदर्भ को val2 के साथ साझा किया गया है। चूंकि, ऑब्जेक्ट अब संपत्ति के संदर्भ को साझा करते हैं, समानता ऑपरेटर दो अलग-अलग ऑब्जेक्ट्स के लिए सही लौटेगा जो दो अलग-अलग मेमोरी एड्रेस को संदर्भित करता है। इसलिए समानता के लिए तुलना करने पर, ऑपरेटर गलत वापस आ जाएगा।

ऑब्जेक्ट डी-स्ट्रक्चरिंग

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

उदाहरण 1

जब एक वस्तु को नष्ट करना चर नाम और वस्तु संपत्ति के नाम से मेल खाना चाहिए।

<script>
let student = {
   rollno:20,
   name:'Prijin',
   cgpa:7.2
}

//destructuring to same property name
   let {name,cgpa} = student
   console.log(name)
   console.log(cgpa)

//destructuring to different name
   let {name:student_name,cgpa:student_cgpa}=student
   console.log(student_cgpa)
   console.log("student_name",student_name)
</script>

उपरोक्त कोड का आउटपुट नीचे देखा जाएगा -

Prijin
7.2
7.2
student_name Prijin

उदाहरण 2

यदि चर और असाइनमेंट दो अलग-अलग चरणों में हैं, तो विनाशकारी वस्तु सिंटैक्स को घेर लिया जाएगा () जैसा कि उदाहरण में दिखाया गया है ({rollno} = student) -

<script>
   let student = {
      rollno:20,
      name:'Prijin',
      cgpa:7.2
   }

   // destructuring to already declared variable
   let rollno;
   ({rollno} = student)
   console.log(rollno)

   // assign default values to variables

   let product ={ id:1001,price:2000} //discount is not product property
   let {id,price,discount=.10} = product
   console.log(id)
   console.log(price)
   console.log(discount)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

20
1001
2000
0.1

उदाहरण 3

नीचे का उदाहरण दिखाता है destructuring का उपयोग करते हुए rest operator और नेस्टेड वस्तुओं को कैसे नष्ट किया जाए।

<script>
   // rest operator with object destructuring
   let customers= {
      c1:101,
      c2:102,
      c3:103
   }

   let {c1,...others} = customers
   console.log(c1)
   console.log(others)

   //nested objects
   let emp = {
      id:101,
      address:{
         city:'Mumbai',
         pin:1234
      }
   }
   let {address} = emp;

   console.log(address)
   let {address:{city,pin}} = emp
   console.log(city)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

101
{c2: 102, c3: 103}
{city: "Mumbai", pin: 1234}
Mumbai