createContext
createContext
আপনাকে একটি context তৈরি করতে দেয় যা component provide বা read করতে পারে।
const SomeContext = createContext(defaultValue)
রেফারেন্স
createContext(defaultValue)
কনটেক্সট তৈরী করবার জন্য যেকোন কম্পোনেন্টের বাইরে createContext
কল করুন।
import { createContext } from 'react';
const ThemeContext = createContext('light');
প্যারামিটার
defaultValue
: এটা হল সেই ভ্যালু যেটা আপনি চান যে কনটেক্সটের থাকুক। কখন? যখন সেই কনটেক্সট যেই component read করবে, ট্রিতে তার উপরে কোন ম্যাচিং কনটেক্সট প্রোভাইডার নেই। যদি আপনার কোন অর্থবহ default ভ্যালু না থাকে, ভ্যালুটাnull
করে দেন। ডিফল্ট ভ্যালু একদম “last resort” ফলব্যাক হিসেবে রাখা হয়। এটা স্ট্যাটিক এবং সময়ের সাথে অপরিবর্তিত থাকে।
রিটার্ন
createContext
একটি কনটেক্সট অবজেক্ট রিটার্ন করে।
কনটেক্সট অবজেক্ট নিজে কোন তথ্য ধারণ করে না। এটা সেই কনটেক্সটকে রিপ্রেজেন্ট করে যেটা অন্যান্য কম্পোনেন্টগুলো read বা provide করে। সাধারণত, কনটেক্সট ভ্যালু নির্দিষ্ট করতে আপনি উপরের কম্পোনেন্টে SomeContext.Provider
ব্যবহার করবেন, এবং এটাকে read করতে নিচের কম্পোনেন্টগুলোতে useContext(SomeContext)
কল করবেন। কনটেক্সট অবজেক্টের কিছু প্রপার্টি আছেঃ
SomeContext.Provider
আপনাকে কম্পোনেন্টে কনটেক্সট ভ্যালু দেয়ার সুযোগ দেয়।SomeContext.Consumer
একটি উপায়ান্তর যা কনটেক্সট ভ্যালু read করার জন্য বিরল ভাবে ব্যবহৃত হয়।
SomeContext.Provider
আপনার কম্পোনেন্টগুলোকে একটি কনটেক্সট প্রোভাইডারে wrap করে ফেলুন এবং এর মাধ্যমে এই সকল কম্পোনেন্টের জন্য এই কন্টেক্সটের মান নির্দিষ্ট করে দিনঃ
function App() {
const [theme, setTheme] = useState('light');
// ...
return (
<ThemeContext.Provider value={theme}>
<Page />
</ThemeContext.Provider>
);
}
Props
value
: এটা হচ্ছে সেই ভ্যালু যেটা আপনি এই প্রোভাইডারের সেই সকল কম্পোনেন্ট দিয়ে read করাতে চান, সেটা যত গভীরেই হোক না কেন। কনটেক্সট ভ্যালু যেকোন টাইপের হতে পারে। যখন প্রোভাইডারের মধ্যে থাকা একটি কম্পোনেন্টuseContext(SomeContext)
কল করে, তখন এটা তার উপরে সবচেয়ে ভিতরকার কনটেক্সট প্রোভাইডারেরvalue
রিসিভ করে।
SomeContext.Consumer
useContext
আসার আগে, কনটেক্সট read করার জন্য একটি পুরনো উপায় ছিলঃ
function Button() {
// 🟡 Legacy way (not recommended)
return (
<ThemeContext.Consumer>
{theme => (
<button className={theme} />
)}
</ThemeContext.Consumer>
);
}
যদিও এই পুরনো উপায়টি এখনো কাজ করে, তবে নতুন করে লেখা কোডে কনটেক্সট read করার জন্য বরং useContext()
ব্যবহার করা উচিতঃ
function Button() {
// ✅ Recommended way
const theme = useContext(ThemeContext);
return <button className={theme} />;
}
Props
children
: একটি ফাংশন। React আপনার pass করা ফাংশনকে কল করবে বর্তমান কনটেক্সট ভ্যালু দিয়ে যেটাuseContext()
এর মতই এলগোরিদম দিয়ে নির্ণয়কৃত, এবং এই ফাংশন থেকে আপনার রিটার্ন করা ফলাফল রেন্ডার করবে। React এই ফাংশন আবার রান করবে এবং প্যারেন্ট কম্পোনেন্টের কনটেক্সট বদলালেই UI আপডেট করে ফেলবে।
ব্যবহার
কনটেক্সট তৈরি
কনটেক্সট কম্পোনেটদেরকে বেশ গভীরে তথ্য পাঠানোর সুযোগ দেয় explicitly props পাঠানো ছাড়াই।
যেকোন কম্পোনেন্টের বাইরে createContext
কল করুন এক বা একাধিক কনটেক্সট তৈরি করার জন্য।
import { createContext } from 'react';
const ThemeContext = createContext('light');
const AuthContext = createContext(null);
createContext
returns a context object. Components can read context by passing it to useContext()
:
function Button() {
const theme = useContext(ThemeContext);
// ...
}
function Profile() {
const currentUser = useContext(AuthContext);
// ...
}
ডিফল্টভাবে, যেই ভ্যালুগুলো তারা পাবে সেগুলো হবে default values যা আপনি কনটেক্সট তৈরি করার সময় নির্দিষ্ট করে দিয়েছিলেন। তবে, এটা নিজে নিজে খুব একটা কাজের না কারণ ডিফল্ট ভ্যালু কখনো বদলায় না।
Context কাজের কেননা আপনি আপনার কম্পোনেন্ট গুলো থেকে অন্যান্য, dynamic মান provide করতে পারবেনঃ
function App() {
const [theme, setTheme] = useState('dark');
const [currentUser, setCurrentUser] = useState({ name: 'Taylor' });
// ...
return (
<ThemeContext.Provider value={theme}>
<AuthContext.Provider value={currentUser}>
<Page />
</AuthContext.Provider>
</ThemeContext.Provider>
);
}
এখন Page
কম্পোনেন্ট এবং এর মধ্যে থাকা যেকোন কম্পোনেন্ট, সেটা যত গভীরেই হোক না কেন, pass হওয়া context ভ্যালু “দেখতে” পারবে। যদি passed হওয়া কনটেক্সট এর ভ্যালু বদলায়, React কনটেক্সট read করে কম্পোনেন্ট পুনরায় render করবে।
কনটেক্সট reading এবং providing এর বিষয়ে আরো পড়ুন এবং উদাহরণ দেখুন।
একটি ফাইল থেকে কনটেক্সট ইমপোর্ট এবং এক্সপোর্ট
প্রায় সময়ই, ভিন্ন ভিন্ন ফাইলের কম্পোনেন্ট এর একই কনটেক্সট এক্সেস করার প্রয়োজন হবে। এ কারণে, সাধারণত, একটা আলাদা ফাইলে কনটেক্সট ডিক্লেয়ার করা হয়। তখন আপনি অন্যান্য ফাইলের জন্য কনতেক্সট এভেইলেবল করতে export
statement ব্যবহার করতে পারেনঃ
// Contexts.js
import { createContext } from 'react';
export const ThemeContext = createContext('light');
export const AuthContext = createContext(null);
এর পর অন্যান্য ফাইলে ডিক্লেয়ার হওয়া কম্পোনেন্টগুলো এই কনটেক্সট রিড বা প্রোভাইড করার জন্য import
statement ব্যবহার করতে পারেঃ
// Button.js
import { ThemeContext } from './Contexts.js';
function Button() {
const theme = useContext(ThemeContext);
// ...
}
// App.js
import { ThemeContext, AuthContext } from './Contexts.js';
function App() {
// ...
return (
<ThemeContext.Provider value={theme}>
<AuthContext.Provider value={currentUser}>
<Page />
</AuthContext.Provider>
</ThemeContext.Provider>
);
}
এটা components ইমপোর্ট এবং এক্সপোর্টের মত কাজ করে।
ট্রাবলশ্যুট
আমি কনটেক্সট ভ্যালু পরিবর্তন করার কোন উপায় খুঁজে পাচ্ছি না
এমন কোড default কনটেক্সট ভ্যালু নির্দেশ করেঃ
const ThemeContext = createContext('light');
এই ভ্যালু কখনো পরিবর্তিত হয় না। যদি React উপড়ে কোন matching provider না পায় তখন এই ভ্যালুটা কেবল মাত্র fallback হিসেবে ব্যবহার করে।
সময়ের সাথে সাথে কনটেক্সট চেঞ্জ করতে, state যোগ করুন এবং কনটেক্সট প্রোভাইডারের মধ্যে components wrap করুন।