ईएस 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