<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Sabbir Hossen</title>
    <description>The latest articles on Forem by Sabbir Hossen (@sabbircs).</description>
    <link>https://forem.com/sabbircs</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1678874%2Ff9b54cd1-09b9-440b-be0f-1114c146408b.png</url>
      <title>Forem: Sabbir Hossen</title>
      <link>https://forem.com/sabbircs</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/sabbircs"/>
    <language>en</language>
    <item>
      <title>Javascript Object Assignments, Copy Or Reference?</title>
      <dc:creator>Sabbir Hossen</dc:creator>
      <pubDate>Tue, 27 Aug 2024 09:26:15 +0000</pubDate>
      <link>https://forem.com/sabbircs/javascript-object-assignments-copy-or-reference-47b</link>
      <guid>https://forem.com/sabbircs/javascript-object-assignments-copy-or-reference-47b</guid>
      <description>&lt;p&gt;জাভাস্ক্রিপ্টে আমরা হর হামেশা অবজেক্ট ব্যবহার করি । অবজেক্ট value কে  যখন আমরা কোন একটা variable এ আসাইন করি তখন ডিফল্ট এপ্রোচ হিসেবে &lt;strong&gt;"="&lt;/strong&gt; এসাইনমেন্ট অপারেটর ব্যবহার করি। আমরা জানি সেই অবজেক্ট,মেমরিতে একটি জায়গায় ষ্টোর করা থাকে এবং variable এ সেই মেমোরি এড্রেস এর রেফারেন্স থাকে। জাভাস্ক্রিপ্ট এ যখন আমরা অবজেক্ট নিয়ে কাজ করি তখন বিভিন্ন কারণে অবজেক্ট এর  আউটকাম বিভিন্ন রকম হয় । তাই আমদের অবজেক্টে এর  আউটকামএর উপর বেইজ করে অবজেক্টকে পরিবর্তন বা ট্রান্সফরমেশন, কপি অথবা ক্লোন করে কাজ করতে হয়। তাহলে আলোচনা করা যাক, কখন এবং কোন উপায়ে একটি জাভাস্ক্রিপ্ট অবজেক্টকে ক্লোন বা কপি করা যেতে পারে। &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Object Reference&lt;/strong&gt; Pass করা। &lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Object Copy or clone&lt;/strong&gt;

&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;&lt;em&gt;Shallow Copy&lt;/em&gt;&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;&lt;em&gt;Deep Copy&lt;/em&gt;&lt;/strong&gt;&lt;/li&gt;
&lt;/ol&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Object Reference Pass করা
&lt;/h2&gt;

&lt;p&gt;মনে করুন আমরা একটি অবজেক্ট তৈরি করেছি এবং সেটি &lt;strong&gt;listData&lt;/strong&gt; নামে একটি &lt;strong&gt;variable&lt;/strong&gt; এ এসাইন করা হয়েছে ।এই সিনারিওতে, &lt;strong&gt;listData&lt;/strong&gt; নামে &lt;strong&gt;variable&lt;/strong&gt;  সেই অবজেক্ট এর একটি মেমরির এড্রেস রেফারেন্স পয়েন্ট করে আছে এবং সেই মেমরি এড্রেস রেফারেন্স এর মধ্যে অবজেক্ট এর &lt;strong&gt;value&lt;/strong&gt; গুলো স্টোর করা আছে। এখন যদি আমরা &lt;strong&gt;copylistData&lt;/strong&gt; নামে একটি &lt;strong&gt;variable&lt;/strong&gt; তৈরি করি এবং &lt;strong&gt;"="&lt;/strong&gt;এসাইনমেন্ট অপারেটর দিয়ে &lt;strong&gt;listData&lt;/strong&gt;কে এসাইন করে দেই তখন &lt;strong&gt;copylistData&lt;/strong&gt; সেই  &lt;strong&gt;listData&lt;/strong&gt; অবজেক্ট এর সেই মেমরির একই অ্যাড্রেস কে পয়েন্ট করে রাখবে। আর এই পদ্ধতিকে বলা হয় &lt;strong&gt;Object Reference&lt;/strong&gt; Pass করা। &lt;/p&gt;

&lt;p&gt;Example:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const listData = { a: 1, b: 2 }; 
const copyListData = listData //Assign the listData into copyListData both are poient same memory address reference

copyListData.a = 3;

console.log(listData.a); // Output: 3 

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;এই পদ্ধতির ২টি বৈশিষ্ট্য রয়েছে&lt;br&gt;
&lt;strong&gt;Shared Reference&lt;/strong&gt;: listData এবং copylistData একই অবজেক্ট এর মেমরি এড্রেস এর রেফারেন্সকে পয়েন্ট করে থাকে। এই ক্ষেত্রে যদি listData তে কোন পরিবর্তন করা হয় তখন সেটার প্রভাব সরাররি copylistData তেও হবে। &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Single Source of Truth&lt;/strong&gt;: এই পদ্ধিত Single Source of Truth এর মত কাজ করে । অর্থাৎ,আপনি যখন listData এর সাথে copylistData কে লিঙ্ক করতে চান বা এই দুই variable এর মধ্যে ধারাবিহিকতা বা সামঞ্জস্যতা বজায় রাখতে চান তাহলে এই পদ্ধিত ব্যবহার করতে পারেন। &lt;/p&gt;
&lt;h2&gt;
  
  
  Object Copy or Clone
&lt;/h2&gt;

&lt;p&gt;জাভাস্ক্রিপ্টে arry এবং object কপি করার ক্ষেত্রে ২টি পদ্ধতি ব্যবহার করা হয় &lt;strong&gt;"Shallow copy"&lt;/strong&gt; অন্যটি &lt;strong&gt;"Deep Copy"&lt;/strong&gt; এই দুইটি পদ্ধতি দিয়ে অবজেক্ট কপি করা হলেও কপির ধরন হয় ভিন্নরকম। কোডের সাইড এফেক্ট পরিহার করা এবং ইফেক্টিভ ভাবে state মেনেজ করার জন্য উপরের দুইটি পদ্ধিতর ভূমিকা অপরিহার্য এবং এগুলো কোনটি কিভাবে কাজ করে তা বুঝা অনেক গুরুত্বপূর্ণ।&lt;/p&gt;
&lt;h3&gt;
  
  
  Shallow Copy
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;Shallow Copy&lt;/strong&gt; বলতে বুঝায়, Object অথবা Array এর top level পর্যন্ত কপি বা ডুপ্লিকেট করা । অর্থাৎ কোন একটা object অথবা  array এর মেমরিতে থাকা  সকল values গুলো কপি করা । কিন্তু সেই অবজেক্ট এর ভিতরে যদি কোন নেস্টেড object অথবা array থাকে তাহলে সেই নেস্টেড object কপি হবে না । তবে সেই ক্ষেত্রে Shallow Copy করার সময় নেস্টেড object এর মেমোরির সেইম রেফারেন্স থেকে যাবে যেটা আমারা উপরে সেকশনে দেখেছিলাম। অবজেক্ট Shallow Copy করার পরেও যদি নেস্টেড অবজেক্ট এর কোন প্রপার্টিজ এর value change করি তাহলে অরজিনাল অবজেক্ট এর মধ্যেও সেই প্রপার্টিজ এর value change হয়ে যাবে। &lt;br&gt;
তবে কোন একটি অবজেক্টকে Shallow Copy করতে চাইলে JS এর &lt;strong&gt;Spread operator&lt;/strong&gt; ব্যবহার করে অবজেক্ট এর Shallow Copy তৈরি করা যায়।&lt;/p&gt;

&lt;p&gt;Example&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const originalObj  = {
    name: 'Sabbir ',
    address: {
        city: 'Narsingdi ',
        zip: '12345'
    }
}; 

// Creating a shallow copy using the spread operator
const shallowCopyObj  = { ...originalObj};
shallowCopyObj.name = 'Fahad'; // This changes only the shallow copy object  
shallowCopyObj.address.city = 'Dhaka '; // This changes both the shallow copy and the originalObj 

console.log(originalObj.name); // Output: 'Sabbir'
console.log(originalObj.address.city); // Output: 'Dhaka '
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;উপরের উদাহারনে যখন আমরা &lt;strong&gt;shallowCopyObj.name = 'Fahad'&lt;/strong&gt; করেছি তখন শুধু shallowCopyObj  এর name এর value chang হয়েছে কিন্তু এতে originalObj  অবজেক্ট এ এর কোন প্রভাব পরবে না। কারণ &lt;strong&gt;Shallow Copy&lt;/strong&gt; করার কারণে আমরা originalObj অবজেক্ট এর একটি ক্লোন তৈরি করেছি । অনুরূপ ভাবে যখন আমরা shallowCopyObj.address.city = 'Dhaka '; করেছি তখন এটি shallowCopyObj  এবং originalObj অবজেক্ট দুই জায়গায় chang হয়েছে কারণ city প্রপারটিজটি address  অবজেক্ট এর একটি প্রপারটিজ।  অর্থাৎ address এর ভিতরে থাকা অবজেক্টটি মেমোরির একটি জায়গায় ষ্টোর করা হয়েছে এবং সেই মেমোরির অ্যাড্রেস এর রেফারেন্স originalObj এবং shallowCopyObj দুই জায়গায় ব্যবহার হচ্ছে বিধায় যেকোনো এক জায়গায় change হওয়ার করনে উভয় জায়গায় পরিবর্তন হচ্ছে। &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;কখন এই পদ্ধিতি ব্যবহার করা উচিত&lt;/strong&gt;&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;যখন আপনি ধুমাত্র টপ-লেভেল প্রোপার্টিজ কপি করতে চান এবং নেস্টেড অবজেক্ট shareable করতে চান তখন ব্যবহার করা যেতে পারে।&lt;/li&gt;
&lt;li&gt;সিম্পল state আপডেট এর ক্ষেত্রে অথবা যখন immutable এর প্রয়োজনীয়তা হয় তখন এই পদ্ধতিটি যথেষ্ট।&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Deep Copy
&lt;/h3&gt;

&lt;p&gt;Deep Copy বলতে বুঝায় কোন একটি object অথবা array এর সব level পর্যন্ত কপি বা ক্লোন করা । অর্থাৎ অবজেক্টে থাকা সকল লেয়ার এর values, নেস্টেড object সহ সকল কিছু কপি করা যা অরজিনাল object বা array এর থেকে সম্পূর্ণ স্বাধীন। এর ফলে কপি অবজেক্ট এর যেকোনো জায়গায় change হলে অরজিনাল অবজেক্ট এর মধ্যে কোন ধরনের প্রভাব পরবে না। এবার আলোচনা করা যাক কোন কোন উপায়ে deep copy করা যেতে পারে। &lt;/p&gt;

&lt;p&gt;Example:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;const originalObj = {
    name: 'Sabbir ',
    address: {
        city: 'Narsingdi ',
        zip: '12345'
    } 
};

// Creating a deep copy using JSON method 
const deepCopyObj  = JSON.parse(JSON.stringify(originalObj ))
deepCopy.name = 'Hasan '; // This changes only deepCopyObj
deepCopyObj.address.city = 'Dhaka '; // This changes only the deepCopyObj

console.log(original.name); // Output: 'Sabbir ' 
console.log(original.address.city); // Output: 'Narsingdi ' 
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;উপরের উদাহারনে, যখন আমরা deepCopyObj.name এবং deepCopyObj.address.city তে পরিবর্তন করেছি তখন শুধু deepCopyObj object এই পরিবর্তন হয়েছে orginalObj object অপরিবর্তিত রেখে।&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;যেই উপায় গুলোতে object কে deep copy বা clone করা যেতে পারে:&lt;/strong&gt;  &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;JSON Method&lt;/strong&gt; : কোন object অথবা array কে Deep Copy করার জন্য সব থেকে সহজ এবং কমন উপায় হচ্ছে object বা array কে &lt;strong&gt;JSON&lt;/strong&gt;এ কনভার্ট করে তারপর &lt;strong&gt;JSON&lt;/strong&gt; থেকে পার্স করে js object এ কনভার্ট করা। সেই জন্য আমরা JSON এর দুইটি মেথড ব্যবহার করতে পারি । &lt;strong&gt;JSON.stringify()&lt;/strong&gt; মেথড ইউজ করবো js object কে json এ কনভার্ট করার জন্য এবং json এ কনভার্ট হওয়ার পর &lt;strong&gt;JSON.parse()&lt;/strong&gt; মেথড ইউজ করবো json কে js object এ রূপান্তর করার জন্য। তবে এই মেথডের কিছু লিমিটেশন রয়েছে যেমন অবজেক্ট  যখন আমরা json এ কনভার্ট করতে যাবো, তখন function, undefiand, NaN, এবং সার্কুলার রেফারেন্স এসব সাপোর্ট করে না । কারণ  json নন সিরিয়ালাইজেবল ডাটা (যেমন : function, undefiend , bigInt ,NaN ইত্যাদি ) গুলো কপি করতে পারেনা। &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Lodash এর _.cloneDeep মেথড&lt;/strong&gt;: এই Lodash লাইব্রেরী _.cloneDeep নামক একটি মেথড প্রদান করে যেটি দিয়ে সহজে যেকোনো কমপ্লেক্স object বা array কে সহজে deep clone করা যায় । &lt;/p&gt;

&lt;p&gt;এছাড়াও আরও অনেক উপায় রয়েছে object deep copy করার জন্য  যেমন structuredClone() মেথড । তবে উপরের উপায় গুলো সব থেকে কমন ইউজ করা হয়। &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;কখন এই পদ্ধিতি ব্যবহার করা উচিত&lt;/strong&gt;&lt;br&gt;
কমপ্লেক্স object এর জন্য একটি ইন্ডিপেন্ডেন্ট  অবজেক্ট ক্লোন করা যেটি সম্পূর্ণ ভাবে আলাদা এবং নেস্টেড object বা array সহ ক্লোন করা। &lt;/p&gt;

</description>
      <category>javascript</category>
      <category>programming</category>
      <category>webdev</category>
      <category>object</category>
    </item>
  </channel>
</rss>
