دنیای جاوااسکریپت ۴ - mutate یا تغییر دادن object

۳۱ مرداد ۱۳۹۹

نکته‌ی اول: object تو در تو وجود ندارد!

object تو در تو وجود ندارد و هر جفت علامت کروشه نشانه‌ی یک آبجکت متمایز و جدید است.

گام اول: تعریف متغیر sherlock
 

let sherlock = {
  surname: 'Holmes',
  address: { city: 'London' }
};
بیایید نگاه دقیق‌تری به فرایند شکل گیری این مدل ذهنی داشته باشیم.

گام دوم: تعریف متغیر sherlock
 

let john = {
  surname: 'Watson',
  address: sherlock.address
};
نتیجه مدل ذهنی مثال بالا
فرایند شکل گیری مدل ذهنی بالا

نکته‌ی دوم: پراپرتی‌های هر شیئ همیشه به یک مقدار اشاره می‌کنن!

نکته‌ی دوم پراپرتی‌های هر شیئ همیشه به یک مقدار اشاره می‌کنن نه یک متغیر یا پراپرتی دیگر

گام سوم: ایجاد تغییر در پراپرتی‌ها

نتیجه کد زیر را با استفاده از مدل ذهنی گام قبلی حدس بزنید.
john.surname = 'Lennon';
john.address.city = 'Malibu';
مدل ذهنی بصورت زیر تغییر می‌کند.
console.log(sherlock.surname); // "Holmes"
console.log(sherlock.address.city); // "Malibu"
console.log(john.surname); // "Lennon"
console.log(john.address.city); // "Malibu"
نگاه دقیقتر به فرایند اعمال تغییرات
همانطور که مشاهده می‌کنید با تغییر مقدار city آدرس john، مقدار city آدرس sherlock هم عوض می‌شود (صرفا پراپرتی city به یک مقدار دیگر اشاره می‌کند زیرا طبق آنچه آموختیم مقادیر Primitive غیر قابل تغییر هستند.)

راه حل اول ایجاد شیئ address جدید

مشکلی که ما در این مرحله با آن روبرو هستیم تغییر آدرس sherlock در زمان تغییر آدرس john است برای این کار با کد زیر می‌توانیم بصورت زیر یک object جدید برای پراپرتی address تعریف کنیم.
// Replace Step 3 with this code:
john.surname = 'Lennon';
john.address = { city: 'Malibu' };
مدل ذهنی کد بالا
همانطور که مشاهده می‌کنید با عملیات انتصاب = به پراپرتی address این پراپرتی به یک آبجکت جدید که با خط نارنجی مشخص شده‌است متصل شد.

راه حل دوم هیچ تغییری در شیئ john ایجاد نکنیم

راه حل بعدی این است که برای اینکه متغیر john شامل مقادیر جدیدی باشد با عملیات انتصاب یک شیئ جدید ایجاد کرده و متغیر john را به آن متصل کنیم.
// Replace Step 3 with this code:
john = {
  surname: 'Lennon',
  address: { city: 'Malibu' }
};
همانطور که مشاهده می‌کنید آبجکتی که قبلا john به آن متصل بوده که شامل پراپرتی surname که به مقدار  "Watson" متصل است و شامل پراپرتی address می‌باشد به حال خود رها شده و با خط جدید نارنجی رنگ به یک مقدار دیگر متصل شده است که ما با عملیات این کار را انجام دادیم.

فهرست مطالب « دنیای جاوااسکریپت »

Berneti