در حال بارگذاری...

انیمیشن‌ها در React

انیمیشن‌ها در React یکی از ابزارهای مهم برای بهبود تجربه کاربری و ایجاد رابط‌های کاربری تعاملی و پویا در ری‌اکت (React) هستند. استفاده صحیح از انیمیشن‌ها می‌تواند به انتقال روان بین صفحات، واکنش‌گرایی بهتر به اقدامات کاربران و افزایش جذابیت بصری برنامه‌های کاربردی کمک کند. در اپلیکیشن‌های مدرن Single Page Applications (SPA)، انیمیشن‌ها نقش کلیدی در القای حس حرفه‌ای و افزایش تعامل کاربر دارند.
در ری‌اکت، انیمیشن‌ها معمولاً در سطح component اعمال می‌شوند که امکان ایجاد components قابل استفاده مجدد و maintainable را فراهم می‌کند. مفاهیم اصلی ری‌اکت مانند component structure، مدیریت state، جریان داده (data flow) و lifecycle، اساس پیاده‌سازی انیمیشن‌های مؤثر هستند. از انیمیشن‌ها می‌توان برای عناصر مختلفی مانند دکمه‌ها، فهرست‌ها، modal‌ها و tooltip‌ها یا انتقال‌های بین صفحات استفاده کرد. کتابخانه‌هایی مانند Framer Motion و React Spring ابزارهای قدرتمندی برای ایجاد انیمیشن‌های روان و بهینه فراهم می‌کنند.
در این آموزش، شما یاد خواهید گرفت چگونه انیمیشن‌ها را به شیوه‌ای بهینه در ری‌اکت پیاده‌سازی کنید، از prop drilling و re-renderهای غیرضروری اجتناب کنید و components قابل استفاده مجدد بسازید. پس از پایان این دوره، توسعه‌دهندگان قادر خواهند بود انیمیشن‌های جذاب و performance-optimized در پروژه‌های مدرن ری‌اکت ایجاد کنند.

مثال پایه

jsx
JSX Code
import React, { useState } from 'react';
import { motion } from 'framer-motion';

function AnimatedBox() {
const [visible, setVisible] = useState(false);

return (
<div style={{ textAlign: 'center', marginTop: '50px' }}>
<button onClick={() => setVisible(!visible)}>
{visible ? 'پنهان کردن' : 'نمایش'} </button>
{visible && (
<motion.div
initial={{ opacity: 0, scale: 0.5 }}
animate={{ opacity: 1, scale: 1 }}
exit={{ opacity: 0, scale: 0 }}
transition={{ duration: 0.5 }}
style={{
width: '100px',
height: '100px',
backgroundColor: '#4CAF50',
margin: '20px auto',
borderRadius: '10px'
}}
/>
)} </div>
);
}

export default AnimatedBox;

در این مثال، کامپوننت AnimatedBox یک جعبه ساده را نمایش می‌دهد که با کلیک روی دکمه ظاهر یا پنهان می‌شود. useState state محلی visible را برای کنترل نمایش جعبه مدیریت می‌کند. motion.div از Framer Motion برای کنترل انیمیشن استفاده می‌شود که شامل initial (حالت شروع)، animate (حالت پایانی) و exit (حالت حذف) است. transition مدت زمان و روانی انیمیشن را تعیین می‌کند.
این کامپوننت مفاهیم کلیدی ری‌اکت را نشان می‌دهد: معماری مبتنی بر کامپوننت، مدیریت state و جریان داده کنترل‌شده. از prop drilling و re-renderهای غیرضروری جلوگیری شده است. Framer Motion با lifecycle کامپوننت هماهنگ است و انیمیشن‌های روان و بهینه ارائه می‌دهد. این الگو را می‌توان به راحتی برای modalها، tooltipها و دکمه‌ها اعمال کرد.

مثال کاربردی

jsx
JSX Code
import React, { useState } from 'react';
import { motion, AnimatePresence } from 'framer-motion';

function TodoList() {
const [todos, setTodos] = useState([]);
const [input, setInput] = useState('');

const addTodo = () => {
if (input.trim() !== '') {
setTodos([...todos, { id: Date.now(), text: input }]);
setInput('');
}
};

const removeTodo = (id) => {
setTodos(todos.filter(todo => todo.id !== id));
};

return (
<div style={{ width: '300px', margin: '50px auto', textAlign: 'center' }}>
<input
value={input}
onChange={(e) => setInput(e.target.value)}
placeholder="کار جدید"
style={{ padding: '8px', width: '70%' }}
/>
<button onClick={addTodo} style={{ padding: '8px' }}>افزودن</button> <AnimatePresence>
{todos.map((todo) => (
<motion.div
key={todo.id}
initial={{ opacity: 0, x: -50 }}
animate={{ opacity: 1, x: 0 }}
exit={{ opacity: 0, x: 50 }}
transition={{ duration: 0.3 }}
style={{
margin: '10px 0',
padding: '10px',
backgroundColor: '#f0f0f0',
borderRadius: '5px',
display: 'flex',
justifyContent: 'space-between'
}}
> <span>{todo.text}</span>
<button onClick={() => removeTodo(todo.id)}>حذف</button>
</motion.div>
))} </AnimatePresence> </div>
);
}

export default TodoList;

در مثال TodoList، AnimatePresence برای مدیریت انیمیشن افزودن و حذف آیتم‌ها استفاده شده است. useState برای مدیریت state محلی input و لیست todos استفاده شده است. هر آیتم یک key یکتا دارد تا React بتواند renderهای غیرضروری را به حداقل برساند و انیمیشن‌ها به درستی اعمال شوند.
استفاده از state immutable باعث جلوگیری از mutationهای مستقیم می‌شود. این الگو برای فهرست‌های پویا، modalها و کامپوننت‌های تعاملی مناسب است. هماهنگی انیمیشن با lifecycle کامپوننت باعث بهبود performance و maintainability می‌شود.

بهترین شیوه‌ها برای انیمیشن‌ها در React شامل ایجاد کامپوننت‌های قابل استفاده مجدد، مدیریت واضح state و جریان داده شفاف است. از prop drilling، renderهای غیرضروری و تغییرات مستقیم state اجتناب کنید. کتابخانه‌هایی مانند Framer Motion و React Spring با lifecycle کامپوننت هماهنگ هستند و انیمیشن‌های بهینه ارائه می‌دهند.
خطاهای رایج شامل ندادن key به آیتم‌های لیست، بروز رسانی نادرست state و چرخه‌های render غیر بهینه است. بهینه‌سازی‌ها مانند memoization، lazy loading و code-splitting باعث افزایش عملکرد می‌شوند. از لحاظ امنیت، محتوای ناامن را در کامپوننت‌های animated رندر نکنید تا از XSS جلوگیری شود. این اقدامات باعث ایجاد انیمیشن‌های امن، عملکرد بالا و maintainable می‌شوند.

📊 جدول مرجع

ری‌اکت (React) Element/Concept Description Usage Example
motion.div کامپوننت Framer Motion برای کنترل انیمیشن div <motion.div animate={{ x: 100 }} />
AnimatePresence مدیریت انیمیشن ورود و خروج کامپوننت‌ها <AnimatePresence>{items.map(item => <motion.div key={item.id} />)}</AnimatePresence>
initial/animate/exit تعیین حالت شروع، انیمیشن و خروج <motion.div initial={{ opacity:0 }} animate={{ opacity:1 }} exit={{ opacity:0 }} />
transition کنترل مدت زمان و زمان‌بندی انیمیشن <motion.div transition={{ duration:0.5 }} />
useState مدیریت state محلی کامپوننت const [state, setState] = useState(initialValue)
key شناسه یکتا برای آیتم‌های لیست، بهینه‌سازی renderها {items.map(item => <motion.div key={item.id} />)}

خلاصه اینکه انیمیشن‌ها در React تجربه کاربری را بهبود می‌بخشند و UI را تعاملی و جذاب می‌کنند. در این آموزش، بر انیمیشن‌های وابسته به state، هماهنگی با lifecycle، ایجاد کامپوننت‌های reusable و بهینه‌سازی performance تمرکز شد. توسعه‌دهندگان یاد می‌گیرند چگونه انیمیشن‌های زیبا، بهینه و maintainable در پروژه‌های ری‌اکت ایجاد کنند.
گام‌های بعدی شامل استفاده از کتابخانه‌های پیشرفته‌تر مانند React Spring، بهینه‌سازی با useMemo و React.lazy و مدیریت ساختارهای پیچیده کامپوننت‌ها است. تمرین، مانیتورینگ عملکرد و توجه به UX باعث بهبود تجربه توسعه‌دهنده و کاربر می‌شود. منابع اضافی شامل مستندات Framer Motion، آموزش‌های پیشرفته React و انجمن‌های توسعه‌دهندگان است.

🧠 دانش خود را بیازمایید

آماده شروع

دانش خود را بیازمایید

خود را با این آزمون تعاملی به چالش بکشید و ببینید موضوع را چقدر خوب درک کرده‌اید

4
سوالات
🎯
70%
برای قبولی
♾️
زمان
🔄
تلاش‌ها

📝 دستورالعمل‌ها

  • هر سوال را با دقت بخوانید
  • بهترین پاسخ را برای هر سوال انتخاب کنید
  • می‌توانید آزمون را هر چند بار که می‌خواهید تکرار کنید
  • پیشرفت شما در بالا نمایش داده می‌شود