Exploring the React component lifecycle: A guide to understanding the different phases.
Al-Amin
Posted on November 29, 2024
এই ব্লগে রিয়েক্ট কম্পোনেন্ট লাইফসাইকেল, এবং তার বিভিন্ন ফেইস সমপর্কে উদাহরণ দিয়ে ব্যাখা করবো যাতে বুঝতে সুবিধা হয়।
রিয়েক্ট কম্পোনেন্টস
লাইফসাইকেলে যাওয়ার আগে, রিয়েক্ট কম্পোনেন্ট কি তা আগে জেনে নেই।
কম্পোনেন্ট হচ্ছে ইউজার ইন্টরফেসের বিল্ডিং ব্লক। রিয়েক্ট কম্পোনেন্ট দুই প্রকারের আছে
- ফাংশনাল কম্পোনেন্ট
- ক্লাস কম্পোনেন্ট
ফাংশনাল কম্পোনেন্ট অতি সহজ এটা জাভাস্ক্রিপ্ট ফাংশনের মতো। ফাংশনাল কম্পোনেন্টের বড় সুবিধা হচ্ছে এখানে হুক(Hook) আছে। যা দিয়ে সহজেই স্টেট ম্যানেজ করা যায় যা ক্লাস কম্পোনেন্ট দিয়ে করা কঠিন
কম্পোনেন্ট লাইফসাইকেলের ধাপ
কম্পোনেন্ট লাফসাইকেল ৩টি মেইন ফেইস দিয়ে গঠিত। মাউন্টিং, আপডেটিং, আনমাউন্টিং। নিচে এদের ব্যাখা দেয়া হলো
মাউন্টিং:
Mounting পর্যায়ে React DOM-এ নতুন একটি কম্পোনেন্ট যুক্ত করে। এই ধাপে কয়েকটি গুরুত্বপূর্ণ lifecycle method রয়েছে:
class Welcome extends React.Component {
constructor(props) {
super(props);
this.state = { message: "Hello, World!" };
}
render() {
return <h1>{this.state.message}</h1>;
}
}
constructor()
- এটি কম্পোনেন্টের প্রথম মেথড।
- state এবং props এর প্রাথমিক মান নির্ধারণে ব্যবহৃত হয়।
render()
- এটি একটি আবশ্যিক মেথড যা JSX রিটার্ন করে।
- কম্পোনেন্ট কিভাবে DOM-এ প্রদর্শিত হবে, তা নির্ধারণ করে।
componentDidMount()
- এটি তখনই কল হয়, যখন কম্পোনেন্ট DOM-এ যুক্ত হয়।
- সাধারণত, API কল বা ডেটা ফেচিংয়ের জন্য এটি ব্যবহৃত হয়।
componentDidMount() {
fetch('https://api.example.com/data')
.then(response => response.json())
.then(data => this.setState({ data }));
}
আপডেটিং:
shouldComponentUpdate()
- এই মেথডের মাধ্যমে নির্ধারণ করা যায়, কম্পোনেন্টটি আপডেট হবে কিনা।
- এটি পারফরম্যান্স উন্নত করতে ব্যবহৃত হয়।
render()
- কম্পোনেন্ট আপডেট হওয়া শেষে এটি কল হয়।
- ডেটা ফেচিং বা DOM ম্যানিপুলেশনের জন্য এটি কার্যকর।
componentDidUpdate()
- এটি তখনই কল হয়, যখন কম্পোনেন্ট DOM-এ যুক্ত হয়।
- সাধারণত, API কল বা ডেটা ফেচিংয়ের জন্য এটি ব্যবহৃত হয়।
componentDidMount() {
fetch('https://api.example.com/data')
.then(response => response.json())
.then(data => this.setState({ data }));
}
আনমাউন্টিং:
componentWillMount
- এটি শেষবারের মতো কল হয়, যখন কম্পোনেন্ট DOM থেকে মুছে ফেলা হয়।
- ক্লিনআপ (যেমন, event listener সরানো) করার জন্য এটি ব্যবহৃত হয়।
componentWillUnmount() {
clearInterval(this.timerID);
}
Posted on November 29, 2024
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.