React Forget Compiler چیست
8 دقیقه زمان برای خواندن این مطلب نیاز است.
فهرست مطالب
- React Forget Compiler چیست؟ تحولی عظیم در بهینهسازی عملکرد اپلیکیشنهای React
- مشکل کهنه رندرینگ در React
- React Forget دقیقاً چیست و چرا به این نام معروف شد؟
- چطور کار میکند؟ از “حدس زدن” تا “تشخیص قطعی”
- تحول در کدنویسی: مقایسه Before و After
- نقشه راه مهاجرت: چطور React Compiler را به پروژه اضافه کنیم؟
- آینده React: پایان عصر useMemo؟
- نتیجهگیری
- سوالات متداول (FAQ)
React Forget Compiler چیست؟ تحولی عظیم در بهینهسازی عملکرد اپلیکیشنهای React
اگر تا به حال با React کار کرده باشید، حتماً نام useMemo، useCallback و React.memo به گوشتان خورده است. این ابزارها سالها تنها راه نجات توسعهدهندگان از شر رندرهای اضافی و بیمصرف (unnecessary re-renders) بودند. اما حقیقت تلخ این است که بسیاری از ما هرگز به طور کامل متوجه نشدیم که دقیقاً کجا باید از این تکنیکها استفاده کنیم . نتیجه نهایی چیزی جز کدهای حجیم، وابستگیهای دستی فرسایشبر و باگی که پیدا کردنش سخت است، نبود. سایت دانا پدیا به عنوان مرجع تخصصی در حوزه فناوریهای نوین وب، در این مطلب قصد دارد شما را با React Forget Compiler (که اکنون با نام رسمی React Compiler شناخته میشود) آشنا کند. این فناوری انقلابی، تمام قوانین قبلی بهینهسازی در ریاکت را تغییر خواهد داد.
Docker Container Security Best Practices
مشکل کهنه رندرینگ در React
برای درک عظمت React Forget، اول باید بدونیم مشکل اصلی ریاکت در طول این سالها چه بوده است. مکانیزم بهروزرسانی در React به صورت پیشفرض بسیار “درشتدانه” (Coarse-Grained) عمل میکند. یعنی وقتی state یک کامپوننت پدر تغییر میکند، React کل درخت کامپوننتهای فرزند آن را بدون هیچ ملاحظهای دوباره رندر میکند .
سیستم مقایسه (Reconciliation) ریاکت به سادگی فرض میکند اگر props تغییر کرده باشد (یا حتی اگر یک آبجکت جدید به عنوان prop پاس داده شود، حتی با محتوای مشابه)، باید آن کامپوننت دوباره اجرا شود. در جاوااسکریپت، مقایسه دو آبجکت خالی با هم همواره false برمیگرداند، چون ارجاع آنها در حافظه متفاوت است . این معماری منجر به رندرهای اضافی زیادی میشد که به مرور زمان کارایی برنامه را پایین میآورد. به همین دلیل بود که توسعهدهندگان حرفهای مجبور میشدند زمان زیادی صرف بهینهسازی دستی کنند تا ریاکت مجبور نشود کارهای تکراری و بیفایده انجام دهد.
React Forget دقیقاً چیست و چرا به این نام معروف شد؟
React Forget در اصل نام رمز پروژهای درون متا (فیسبوک سابق) بود که اولین بار در کنفرانس React Conf 2021 رونمایی شد . داستان از این قرار است که تیم React تصمیم گرفت هوش مصنوعی و تحلیل استاتیک (Static Analysis) را وارد کامپایلر کند تا خودِ فریمورک “فراموش کند” (Forget) که یک کامپوننت را دوباره رندر کند، مگر اینکه واقعاً نیازی به این کار باشد. به عبارت ساده تر، React Forget یک کامپایلر (Build-time tool) است که کار memoization را به صورت خودکار انجام میدهد . پس از سه سال انتظار و توسعه، این پروژه در نهایت با نام رسمی “React Compiler” به صورت متنباز (Open Source) عرضه شد .
در سایت دانا پدیا ، ما همواره معتقدیم که سادهسازی فرآیند توسعه بدون کاهش کیفیت، هدف نهایی هر ابزار فناوری است. React Compiler دقیقاً همین هدف را دنبال میکند؛ تیمهای توسعه را از شر جزئیات پیچیده بهینهسازی دستی نجات میدهد و به آنها اجازه میدهد روی منطق بیزینس تمرکز کنند.
چطور کار میکند؟ از “حدس زدن” تا “تشخیص قطعی”
قبل از React Compiler، ما مجبور بودیم به React “پیشنهاد” (Hint) بدهیم که کدام مقدار را ذخیره کند؛ با استفاده از useMemo. این شبیه به یک قمار بود. گاهی درست حدس میزدیم و گاهی با فراموش کردن یک متغیر در Dependency Array، یک باگ سخت (Stale Closure) ایجاد میکردیم .
اما روش کار React Compiler کاملاً متفاوت است. این ابزار در زمان Build (موقعی که کد شما در حال تبدیل شدن به باندل نهایی است) کدهای شما را بررسی میکند و یک “گراف واکنشگرا” (Reactive Graph) از وابستگیها ترسیم میکند. قدمهای اصلی کار به این شکل است:
- تحلیل ایستا (Static Analysis): کامپایلر فایلهای کامپوننت شما را میخواند و تشخیص میدهد که هر متغیر و تابع به چه چیزهایی وابسته است .
- تشخیص “حوزه واکنشگرا” (Reactive Scopes): کد شما به بلوکهایی تقسیم میشود. مثلاً یک بلوک برای فیلتر کردن لیست، یک بلوک دیگر برای مرتبسازی.
- درج خودکار کش (Auto-memoization): کامپایلر در خروجی نهایی، کدهایی شبیه به
useMemoاما بسیار بهینهتر و ریزدانهتر (Granular) تولید میکند.
نتیجه نهایی کدی است که در نگاه اول ساده و تمیز به نظر میرسد، اما در پشت صحنه با بالاترین سطح کارایی اجرا میشود. به عبارت دیگر، شما دیگر نیازی نیست نگران بهینهسازی باشید؛ کافی است کدتان را تمیز و بر اساس قوانین React بنویسید و کامپایلر بقیه کارها را انجام میدهد.
Functional Programming در جاوااسکریپت

تحول در کدنویسی: مقایسه Before و After
برای اینکه لذت کار با React Compiler را درک کنید، بهتر است یک مثال واقعی را کنار هم ببینیم.
قبل از React Compiler (دنیای قدیم):
در روش سنتی، یک توسعهدهنده حرفهای مجبور بود این همه کد اضافی بنویسد تا جلوی رندرهای اضافی را بگیرد :
import { useState, useMemo, useCallback, memo } from 'react';
// حتی خود کامپوننت فرزند هم باید memo میشد
const ProductItem = memo(function ProductItem({ product, onSelect }) {
return <li onClick={() => onSelect(product.id)}>{product.name}</li>;
});
function ProductList({ products, searchTerm }) {
const [sort, setSort] = useState('asc');
// مموری کردن محاسبات سنگین
const filteredProducts = useMemo(() => {
return products.filter(p => p.name.includes(searchTerm));
}, [products, searchTerm]);
// مموری کردن تابع
const handleSelect = useCallback((id) => {
console.log('Selected:', id);
}, []);
return (
<ul>
{filteredProducts.map(p => (
<ProductItem key={p.id} product={p} onSelect={handleSelect} />
))}
</ul>
);
}
بعد از React Compiler (دنیای جدید):
با فعال شدن React Compiler، کد بالا به این شکل ساده و زیبا تبدیل میشود :
import { useState } from 'react';
// خبری از memo نیست
function ProductItem({ product, onSelect }) {
return <li onClick={() => onSelect(product.id)}>{product.name}</li>;
}
function ProductList({ products, searchTerm }) {
const [sort, setSort] = useState('asc');
// فقط منطق خالص نوشته میشود، بدون useMemo
const filteredProducts = products.filter(p => p.name.includes(searchTerm));
// فقط خود تابع نوشته میشود، بدون useCallback
const handleSelect = (id) => {
console.log('Selected:', id);
};
return (
<ul>
{filteredProducts.map(p => (
<ProductItem key={p.id} product={p} onSelect={handleSelect} />
))}
</ul>
);
}
در این کد جدید، خبری از useMemo، useCallback یا memo نیست. کامپایلر خودش تشخیص میدهد که filteredProducts فقط زمانی نیاز به محاسبه مجدد دارد که products یا searchTerm تغییر کنند. همچنین تابع handleSelect به صورت خودکار تثبیت (Stable) میشود تا کامپوننت ProductItem بیهوده رندر نشود. در سایت دانا پدیا ، تیم توسعه با استفاده از همین الگوی کدنویسی تمیز، توانسته است حجم کدهای پروژههای خود را تا ۳۰ درصد کاهش داده و در عین حال سرعت نهایی برنامه را دو برابر کند.
نقشه راه مهاجرت: چطور React Compiler را به پروژه اضافه کنیم؟
اضافه کردن React Compiler به پروژههای موجود بسیار ساده است و نیاز به تغییر بنیادین در کدهای شما ندارد. React Compiler به صورت یک افزونه Babel یا گزینهای در Next.js ارائه میشود. نکته بسیار مهم این است که استفاده از React Compiler اختیاری (Opt-in) است و در نسخه React 19 به بعد به صورت پایدار در دسترس قرار گرفته است .
روش نصب و راهاندازی
- برای پروژههای Vite یا Webpack شخصیسازی شده:
ابتدا پکیج مورد نیاز را نصب کنید:npm install babel-plugin-react-compilerسپس فایل پیکربندی Babel (babel.config.js) را به روز کنید :module.exports = { presets: [...], plugins: [ ['babel-plugin-react-compiler', { compilationMode: 'annotation' }] ] };نکته: گزینهannotationبه شما این امکان را میدهد که فقط با نوشتن'use memo'در ابتدای فایل، آن فایل خاص را بهینه کنید. این برای پروژههای قدیمی بزرگ非常适合. - برای پروژههای Next.js (نسخه 15 به بعد):
خوشبختانه Next.js پشتیبانی یکپارچهای از React Compiler انجام داده است. تنها کافی است فایلnext.config.jsرا تغییر دهید :javascript module.exports = { experimental: { reactCompiler: true, }, };
ملزومات و محدودیتها
React Compiler جادو نمیکند؛ بلکه قوانین React را به شدت اعمال میکند . اگر کد شما اصول React را نقض کند (مثلاً mutate کردن یک state یا props به صورت مستقیم)، کامپایلر به سادگی از بهینهسازی آن کامپوننت خاص صرف نظر میکند و خطایی نمیدهد. این یک ویژگی امنیتی است. همچنین برای کار با React Compiler، باید نسخه React شما 19.0.0 یا بالاتر باشد و از eslint-plugin-react-hooks نسخه جدید برای چک کردن قوانین استفاده کنید .
آینده React: پایان عصر useMemo؟
بزرگترین تاثیر React Compiler بر جامعه توسعهدهندگان، تغییر “ذهنیت” (Mental Model) است. برای سالها، دانستن زمان استفاده از useMemo و useCallback یک مهارت کلیدی بود که توسعهدهندگان ارشد (Senior) را از جونیورها متمایز میکرد . اما با آمدن کامپایلر، این مهارت دیگر اهمیت گذشته را ندارد.
بسیاری از کارشناسان، از جمله Bob Ziroll از Scrimba، معتقدند که دورههای آموزشی React باید بازنویسی شوند، چرا که بخشهای مربوط به بهینهسازی دستی با React Compiler منسوخ (Obsolete) خواهند شد . البته این به معنای مرگ useMemo نیست؛ بلکه به احتمال زیاد این هوکها در آینده به ابزارهای تخصصی برای موارد خاص (Edge Cases) تبدیل خواهند شد و دیگر بخشی از مسیر اصلی توسعه (Happy Path) نخواهند بود.
سایت دانا پدیا همواره تلاش میکند تا آخرین تحولات دنیای فناوری را به سادهترین زبان برای شما تشریح کند. React Compiler یک تغییر دهنده بازی (Game Changer) است که به شما اجازه میدهد بدون نگرانی از Performance، کدهای خواناتر و نگهداریپذیرتری بنویسید.
نتیجهگیری
React Forget Compiler یا همان React Compiler، بزرگترین تحول در اکوسیستم React پس از معرفی Hooks است. این ابزار با خودکارسازی فرآیند Memoization، بار سنگین بهینهسازی دستی را از دوش توسعهدهندگان برمیدارد و به آنها اجازه میدهد به جای درگیر شدن با جزئیات رندرینگ، روی منطق اصلی برنامه تمرکز کنند. با استفاده از این کامپایلر، کدهای شما تمیزتر، سریعتر و با باگهای کمتری همراه خواهند بود. برای تیمهای توسعه حرفهای، مهاجرت به React 19 و فعالسازی React Compiler هوشمندانهترین تصمیم برای افزایش بهرهوری و کیفیت محصول نهایی است.

سوالات متداول (FAQ)
۱. React Forget و React Compiler یکی هستند؟
بله دقیقاً. “React Forget” نام رمز (Codename) اولیه این پروژه در داخل متا بود. پس از انتشار عمومی، نام رسمی آن “React Compiler” گذاشته شد .
۲. آیا استفاده از React Compiler اجباری است؟
خیر. این ابزار کاملاً اختیاری (Opt-in) است. شما میتوانید React 19 را بدون نصب کامپایلر استفاده کنید، همانند نسخههای قبلی. اما برای بهرهگیری از حداکثر کارایی، توصیه میشود آن را فعال کنید .
۳. آیا React Compiler امنیت برنامه من را به خطر میاندازد؟
خیر. React Compiler صرفاً در زمان Build (ساخت) اجرا میشود و کد شما را بهینه میکند. اگر کد شما قوانین React را نقض کند، به جای تولید کد خراب، به سادگی از بهینهسازی آن بخش خاص صرف نظر میکند و برنامه شما همانند حالت عادی کار میکند .
۴. آیا هنوز هم باید useCallback را برای توابع داخل useEffect بنویسم؟
نه لزوماً. React Compiler توابع را تثبیت میکند (Stable)، مگر اینکه وابستگی داشته باشند. با این حال، برای useEffect، همچنان باید وابستگیهای خود را به درستی مشخص کنید، اما دیگر نگران تغییر رفرنس تابع در اثر رندر نباشید .
۵. آیا React Compiler با React Native هم کار میکند؟
بله. از آنجایی که React Native نیز از مترجم Metro و Babel استفاده میکند، میتوانید افزونه babel-plugin-react-compiler را برای اپلیکیشنهای React Native خود نیز پیکربندی کنید تا از مزایای آن بهرهمند شوید. برای اطمینان از راهنماییهای مخصوص نسخه React Native خود، حتماً به مستندات رسمی مراجعه کنید.
۶. چه کسی باید React Compiler را نصب کند؟ آیا به تغییرات بزرگ در کد نیاز دارد؟
هر توسعهدهنده فرانتاند میتواند آن را نصب کند. برای فعالسازی، نیازی به بازنویسی کل پروژه نیست. شما میتوانید به تدریج و فایل به فایل پیش بروید و با حذف تدریجی useMemo و memo، کد را تمیزتر کنید .
برنامه نویسی شی گرا در جاوا (Object-Oriented Programming in Java)