3.4 Lifting State Up
Welcome to React Next Documentation Bangla
Lifting State Up বা স্টেটকে উপরে নেওয়া
কি বুঝায় লিফটিং স্টেট আপ?
lifting state up মানে হলো, যখন তুমি কোন কম্পোনেন্টের ভিতরের স্টেটকে তার প্যারেন্ট কম্পোনেন্টে নিয়ে যাও। এখন কেন এটা করতে হবে? কারণ, ধরো, তুমি যদি স্টেটটাকে নিচের লেভেলে রেখে দাও, তাহলে সেই কম্পোনেন্টটা হয়তো নিজস্বভাবে স্টেট ম্যানেজ করবে, কিন্তু অন্যান্য কম্পোনেন্ট সেটার সাথে সংযোগ করতে পারবে না।
যেমন, তোমার যদি একটা প্যারেন্ট কম্পোনেন্ট থাকে যেখানে দুইটা sibling কম্পোনেন্ট থাকে, এবং এক sibling কম্পোনেন্টে কিছু ডাটা জেনারেট হয় যা আরেকটা sibling কম্পোনেন্টে দরকার হয়, তখন সেই স্টেটটা লোকাল রাখলে হবে না। এ অবস্থায় আমরা সেই স্টেটকে প্যারেন্ট কম্পোনেন্টে নিয়ে যাই। তাহলে প্যারেন্ট সেই স্টেটটাকে সব চাইল্ডের মধ্যে ভাগ করে দিতে পারবে।
উদাহরণঃ
তুমি ভাবো, তুমি একটা App কম্পোনেন্ট বানাচ্ছো। সেই App-এর ভিতরে দুইটা sibling কম্পোনেন্ট আছে—Product এবং Cart। এখন Product-এ যদি কিছু প্রোডাক্ট সিলেক্ট করা হয়, সেই ইনফরমেশন তোমার Cart কম্পোনেন্টেও লাগবে। তখন কি করতে হবে?
প্রথমে একটা সাধারণ App কম্পোনেন্ট দেখো যেখানে Product এবং Cart আছে:
এখন ধরো Product কম্পোনেন্টে তুমি কিছু স্টেট রাখো যেটা Cart-এ দরকার। তুমি সেটা সরাসরি Cart-এ পাঠাতে পারছো না কারণ তারা Sibling। তাই, আমরা সেই স্টেটটাকে App-এ নিয়ে যাবো।
যদি স্টেটকে App-এ নিয়ে যাই, তখন আমরা props এর মাধ্যমে সেই ডাটা Product আর Cart-এ পাঠাতে পারবো। এই পদ্ধতিটাই হলো lifting state up।
কিভাবে স্টেটকে উপরে নেয়া হয়?
এখন ধরো, Product-এ একটা প্রোডাক্টের নাম আর প্রাইস রাখা হয়েছে। আর সেই ডাটা Cart-এ শো করা হবে। আমরা শুরুতে Product-এ স্টেট নিবো, কিন্তু পরে আমরা সেটাকে App-এ নিয়ে যাবো:
এবার, আমরা App-এ এই স্টেটগুলো নিয়ে কাজ করবো, এবং Cart-এও সেই ডাটা পাস করবো:
App-এ এখন স্টেট আছে যা Product থেকে ডাটা নেয় এবং Cart-এ পাঠায়। এইভাবে আমরা স্টেটকে প্যারেন্টে তুলে এনেছি এবং সেটা সব চাইল্ড কম্পোনেন্টে ভাগ করে দিয়েছি।
Controlled এবং Uncontrolled Components
এখন আমরা Controlled এবং Uncontrolled কম্পোনেন্ট সম্পর্কে জানবো। এগুলো বুঝতে হলে তোমাকে প্রথমে জানতে হবে যে, রিয়াক্টে স্টেট আর প্রপ্স কিভাবে কাজ করে।
Controlled Components
Controlled Components মানে হলো, সেইসব কম্পোনেন্ট যেগুলোর স্টেট প্যারেন্টের কন্ট্রোলে থাকে। প্যারেন্ট কম্পোনেন্টে স্টেট থাকে এবং সেই স্টেটকে প্রপ্স দিয়ে চাইল্ড কম্পোনেন্টে পাঠানো হয়। চাইল্ড কম্পোনেন্ট নিজের স্টেট নিয়ন্ত্রণ করতে পারে না, সে শুধু প্যারেন্ট থেকে প্রপ্স নেয় আর সেটার উপর ভিত্তি করে কাজ করে।
এটা তুমি ভালোভাবে বুঝতে পারবে নিচের উদাহরণ দিয়ে:
এখানে ChildComponent পুরোপুরি ParentComponent এর উপর নির্ভরশীল। প্যারেন্ট কম্পোনেন্টের স্টেট inputValue কে প্রপ্স দিয়ে পাঠানো হয়েছে, এবং onChange ইভেন্টও পাঠানো হয়েছে।
Uncontrolled Components
Uncontrolled Components হলো সেই কম্পোনেন্ট যেগুলো নিজেদের স্টেট ম্যানেজ করে। এর মানে হলো, প্যারেন্ট কম্পোনেন্টের কোনো কন্ট্রোল থাকে না। সাধারণত ref এর মাধ্যমে ডম এলিমেন্টে সরাসরি অ্যাক্সেস করা হয়।
নিচে একটা Uncontrolled Component এর উদাহরণ দেওয়া হলো:
এখানে input ফিল্ডটা পুরোপুরি নিজস্বভাবে কাজ করছে। তুমি ref দিয়ে সেই input-এর ভ্যালু অ্যাক্সেস করতে পারো, কিন্তু সেটা প্যারেন্ট কম্পোনেন্টের কোন স্টেটের উপর নির্ভর করছে না।
শেষ কথা
তুমি যদি স্টেটগুলোকে ভালোভাবে ম্যানেজ করতে চাও, তাহলে কখন স্টেট উপরে নিয়ে আসবে (লিফট করবে) আর কখন সেটা নিজের মধ্যে রাখবে, সেটা বুঝতে হবে। Controlled কম্পোনেন্ট তখনই ভালো যখন প্যারেন্ট সব কিছুর কন্ট্রোল রাখতে চায়। আর Uncontrolled কম্পোনেন্ট তখনই ভালো যখন কম্পোনেন্ট নিজেই সব কিছু নিয়ন্ত্রণ করতে চায়।