3.7 State Reducer
Welcome to React Next Documentation Bangla
Reducer এবং Context দিয়ে Scaling Up
reducer ফাংশন আমাদের কম্পোনেন্টের জটিল স্টেট লজিকগুলোকে একটি কেন্দ্রীয় স্থানে ম্যানেজ করার সুবিধা দেয়। এটি স্টেট পরিবর্তনের জন্য একটি নির্দিষ্ট পদ্ধতি নির্ধারণ করে। অন্যদিকে, Context আমাদের props drilling ছাড়াই ডাটা শেয়ার করার সুযোগ দেয়। যখন আমরা reducer এবং Context একত্রে ব্যবহার করি, তখন জটিল কম্পোনেন্টগুলোকে অনেক সহজ এবং সুন্দরভাবে তৈরি করা সম্ভব হয়।
Reducer এবং Context একত্রে ব্যবহার করা
আমরা তিনটি ধাপে Context এবং Reducer একত্রে ব্যবহার করতে পারি, যা আমাদের যেকোনো কম্পোনেন্টে ডাটা পাস করতে সাহায্য করবে।
- Context তৈরি করা।
- একটি Reducer তৈরি করা এবং Provider এর মাধ্যমে state এবং dispatch প্রদান করা।
- কম্পোনেন্ট ট্রির যেকোনো স্থানে context ব্যবহার করা।
Context তৈরি করা (একটি কনটেক্সট তৈরি করা)
একটি আলাদা ফাইলে একটি কনটেক্সট তৈরি করতে হবে এবং এটি এক্সপোর্ট করতে হবে, যাতে অন্যান্য ফাইল থেকে এটি ইম্পোর্ট করা যায়। কনটেক্সট হচ্ছে React-এর একটি বৈশিষ্ট্য যা আমাদের গ্র্যান্ড প্যারেন্ট কম্পোনেন্ট থেকে ডেটা পাঠাতে সাহায্য করে।
এখানে, createContext(0) ফাংশনটি একটি নতুন কনটেক্সট তৈরি করছে যার ডিফল্ট ভ্যালু ০। এটি পরবর্তী ধাপে ব্যবহৃত হবে।
Reducer তৈরি করা এবং Provider এর মাধ্যমে state এবং dispatch প্রদান করা (একটি রিডিউসার তৈরি করতে হবে)
আমাদের একটি Reducer তৈরি করতে হবে। এই Reducer এর state এবং dispatch ফাংশনগুলোকে আমাদের যে কম্পোনেন্টের প্রয়োজন হবে, সেগুলোর মেইন প্যারেন্টে পাঠাতে হবে। এতে সব নেস্টেড চাইল্ড কম্পোনেন্ট সেই ডাটা এক্সেস করতে পারবে।
কিভাবে Reducer তৈরি করতে হয় তা জানতে এখানে ক্লিক করুন
Context ব্যবহার করা (কম্পোনেন্ট ট্রির যেকোনো স্থানে কনটেক্সট ব্যবহার করে ডাটা রিসিভ করা)
এখন আমাদের যেসব কম্পোনেন্টে ডাটা প্রয়োজন, সেখানেই আমরা useContext ব্যবহার করে ডাটা রিসিভ করতে পারবো। এই উদাহরণের ক্ষেত্রে, আমাদের শুধুমাত্র Counter কম্পোনেন্টে ডাটা প্রয়োজন, তাই আমরা এখান থেকে ডাটা রিসিভ করবো।
এখন যদি আমরা কোড রান করি, দেখবো এটি পারফেক্টলি কাজ করছে। মূলত এই হলো তিনটি ধাপ, এই তিনটি ধাপেই আমরা Reducer এর সাথে Context ব্যবহার করতে পারি।
সব কিছুকে একটি ফাইলে স্থানান্তরিত করা - একটি ভালো পদ্ধতি
এখন আমরা আরেকটি সুন্দর পদ্ধতিতে Reducer এর সাথে Context ব্যবহার করবো। আমরা আমাদের Context সম্পর্কিত সমস্ত কাজকে একটি আলাদা ফাইলে রাখতে পারি এবং সেখান থেকেই স্টেটগুলোও ম্যানেজ করতে পারি।
এভাবে আমাদের মেইন প্যারেন্ট কম্পোনেন্ট থেকে সমস্ত কিছু সরিয়ে নিয়ে আমরা একটি আলাদা ফাইলে ম্যানেজ করতে পারি।
এছাড়াও, আমরা Context কে বার বার কল না করে একটি আলাদা কাস্টম হুক বানিয়ে নিতে পারি, যা আমাদের কোডের পুনরাবৃত্তি কমাতে সাহায্য করবে।
এখন আমরা useCounter হুক ব্যবহার করে যেকোনো কম্পোনেন্টে সেই কনটেক্সটের ডেটা এক্সেস করতে পারি।
অন্য যেকোনো কম্পোনেন্ট থেকে কনটেক্সট ব্যবহার করা
এখন যে কোন কম্পোনেন্টে আমরা useCounter ব্যবহার করে ডেটা নিয়ে আসতে পারি।
এখন, Counter কম্পোনেন্টের পরিবর্তে, আমরা useCounter হুক ব্যবহার করতে পারি, যা আমাদের কোড আরও পরিষ্কার এবং কার্যকর করবে।