بوت‌کمپ‌های برنامه‌نویسی دانشکار

شروع یادگیری
reactبرنامه‌نویسی

React Native چیست و چگونه کار می‌کند؟

به‌طور معمول شما اگر بخواهید یک اپلیکیشن موبایل را به‌صورت جداگانه (با سوئیفت برای iOS و با کاتلین برای اندروید) عرضه کنید، باید دوبرابر زمان و هزینه‌ی بیشتری بپردازید. اما ری‌اکت نیتیو (React Native) این دوباره‌کاری و هزینه‌ی دوچندان را از بین می‌برد. در ادامه به شما می‌‌گوییم که React native چیست و چگونه کار می‌کند.

ری‌ اکت نیتیو React Native چیست؟

ری‌اکت نیتیو یک فریم‌ورک جاوااسکریپتی (JavaScript) است که به شما اجازه می‌دهد با نوشتن کامپوننت‌های React، اپلیکیشن موبایل کاملاً Native برای iOS و اندروید بسازید.

این فریم‌ورک از فلسفه «یک‌بار یاد بگیر، همه‌جا بنویس» پیروی می‌کند. یعنی بخش زیادی از کد را می‌توانید بین پلتفرم‌ها مشترک استفاده کنید و فقط زمانی که به قابلیت‌های خاص هر سیستم‌عامل نیاز دارید، مستقیماً سراغ APIهای Native بروید.

در این روش:

  • شما یک کدبیس واحد دارید.
  • این کد (تا حدود ۹۰ درصد) به‌صورت هم‌زمان برای هر دو پلتفرم (اندروید و آیفون) خروجی می‌دهد که این موضوع به‌طور چشم‌گیری کارهای تکراری را کاهش می‌دهد.

برخلاف فریم‌ورک‌های هیبریدی قدیمی (مثل Cordova یا Ionic)، ری اکت نیتیو از WebView استفاده نمی‌کند. یعنی رابط کاربری شما HTML/CSS نیست که داخل یک مرورگر جاسازی شده باشد؛ بلکه وقتی یک عنصر View یا Text می‌نویسید، مستقیماً به اجزای Native سیستم‌عامل تبدیل می‌شود.

پیشنهادی: معرفی پرطرفدارترین فریم‌ ورک‌های فرانت‌اند

معرفی  react native

چرا فیسبوک ری‌ اکت نیتیو را ساخت؟

فیسبوک این فریم‌ورک را پس از عملکرد ضعیف اپلیکیشن موبایل HTML5 خود ایجاد کرد. اپ موبایل HTML5 فیسبوک آن‌قدر کند و ضعیف عمل می‌کرد که مارک زاکربرگ بعدها گفت:

اعتماد به فناوری وب «بزرگ‌ترین اشتباهی بود که شرکت ما انجام داد».

در پاسخ به این شکست، مهندسی به نام Jordan Walke یک نمونه اولیه ساخت که می‌توانست اجزای رابط کاربری iOS را مستقیماً از طریق جاوا اسکریپت رندر کند.

پس از موفقیت این ایده در یک هکاتون داخلی در سال ۲۰۱۳، فیسبوک در سال ۲۰۱۵ ری اکت نیتیو را به‌صورت متن‌باز منتشر کرد و ابتدا از آن در اپ‌هایی مثل Ads Manager و Groups استفاده کرد.

از زمان متن‌باز شدن React Native در سال ۲۰۱۵، شرکت‌هایی مثل Instagram، Discord و Shopify از آن استفاده کرده‌اند تا دوباره‌کاری در توسعه را حذف کنند، بدون اینکه تجربه کاربری قربانی شود.

 با ری اکت نیتیو، سرعت توسعه وب را دارید و در عین حال به عملکرد اپ Native موبایل می‌رسید؛ آن هم بدون سازش‌ها و محدودیت‌های معمول.

عکس لوگوی فیسبوک و  react native

ری‌اکت نیتیو چگونه کار می‌کند؟

اپلیکیشن React Native در سه لایه اصلی اجرا می‌شود. لایه اول، لایه JavaScript است که منطق اصلی برنامه را با استفاده از یک موتور JavaScript اجرا می‌کند. در نسخه‌های جدید React Native معمولاً به‌صورت پیش‌فرض از Hermes استفاده می‌شود، اما در صورت نیاز می‌توان موتورهایی مثل JavaScriptCore یا گزینه‌های دیگر را هم تنظیم کرد. انتخاب و پشتیبانی از این موتور در نسخه‌های جدید، به‌طور شفاف در اختیار توسعه‌دهنده است.

وقتی شما در کدتان اجزای رابط کاربری (UI) را تعریف می‌کنید، فریم‌ورک پیام‌هایی سریال‌شده را از طریق یک Bridge غیرهم‌زمان به لایه Native می‌فرستد. لایه Native این پیام‌ها را دریافت می‌کند و بر اساس آن‌ها، ویجت‌های واقعی سیستم‌عامل را می‌سازد.

در این فرآیند:

  • Thread جاوا اسکریپت منطق برنامه را اجرا می‌کند.
  • Shadow Thread با استفاده از موتور Yoga محاسبات مربوط به چیدمان (Layout) را انجام می‌دهد.
  • UI Thread مسئول رندر نهایی و نمایش رابط کاربری است.

برای بیشتر تعامل‌ها، این زنجیره پردازش عملکردی در حد اپ‌هایی دارد که مستقیماً با Swift یا Kotlin نوشته شده‌اند. با این حال، در به‌روزرسانی‌های بسیار پرتکرار، ممکن است سربار Bridge خودش را نشان بدهد.

معماری جدید برای حذف همین گلوگاه‌ها طراحی شده است:

  • Fabric جایگزین Bridge شده و از JavaScript Interface (JSI) برای ارتباط مستقیم و هم‌زمان استفاده می‌کند.
  • TurboModules فرآیند بارگذاری ماژول‌های Native را سریع‌تر و سبک‌تر می‌کنند.
  • رندر جدید با قابلیت‌های هم‌زمان (Concurrent) در React 18 هماهنگ است.

توسعه‌دهندگانی که زودتر از این معماری استفاده کرده‌اند، گزارش داده‌اند که:

  • انیمیشن‌ها روان‌تر شده‌اند.
  • مصرف حافظه کمتر شده است.
  • بی‌نیاز به تغییر کد اپلیکیشن شده‌اند.

نتیجه: در عمل، شما با ذهنیت React فکر می‌کنید، با Hot Reload سریع‌تر تغییرات را می‌بینید و در نهایت خروجی‌ای منتشر می‌کنید که وقتی کاربر با آن کار می‌کند، کاملاً حس یک اپ Native واقعی را می‌دهد.

مزایای React Native چیست؟

مزیت اصلی React Native در داشتن کدبیس مشترک، تیم کوچک‌تر و بازخورد سریع‌تر است. به‌جای اینکه برای هر تغییر چند دقیقه منتظر بمانید، در چند ثانیه نتیجه را می‌بینید. تیم‌های توسعه معمولاً گزارش می‌دهند که با React Native، صرفه‌جویی قابل‌توجهی در زمان داشته‌اند و بهره‌وری توسعه‌دهندگان‌شان افزایش یافته است.

مزایای  react native

۱. یک‌بار بنویس، همه‌جا منتشر کن

تیم‌های توسعه می‌توانند ۷۰ تا ۹۰ درصد کد را بین iOS و Android مشترک استفاده کنند. این اشتراک مستقیم به سرعت بیشتر در توسعه منجر می‌شود؛ پروژه‌های چندپلتفرمی معمولاً سریع‌تر از ساخت جداگانه نسخه Native برای هر سیستم‌عامل تمام می‌شوند، هرچند آمار دقیقی برای برتری سرعت ۳۰ تا ۵۰ درصدی وجود ندارد.

البته همچنان در برخی موارد خاص به کد وابسته به پلتفرم نیاز دارید؛ (مثل: منطق اختصاصی PushKit در iOS یا SDKهای پرداخت خاص در Android) اما این کدها معمولاً در ماژول‌های جدا و ایزوله قرار می‌گیرند.

در بیشتر مواقع، تفاوت‌های بین پلتفرم‌ها با یک شرط ساده حل می‌شود:

با محدود کردن تفاوت‌ها به بخش‌های مشخص، ذهن توسعه‌دهنده کمتر درگیر پیچیدگی می‌شود و Pull Requestها هم مرتب‌تر و متمرکزتر می‌مانند.

مطالعات نشان داده‌اند که این رویکرد نسبت به داشتن دو تیم جدا برای توسعه Native باعث صرفه‌جویی قابل توجه در هزینه‌ها می‌شود، هرچند درصد دقیقی اعلام نشده است. React Native برابری قابلیت‌ها بین دو پلتفرم را از یک «چالش مالی» به یک وضعیت پیش‌فرض و طبیعی تبدیل می‌کند.

۲. استفاده از مهارت‌های موجود جاوااسکریپت

اگر شرکت شما از قبل روی توسعه وب سرمایه‌گذاری کرده باشد، React Native می‌تواند فوراً از همان نیروی انسانی استفاده کند. مدل ذهنی توسعه‌دهنده (کامپوننت‌ها، props و state) تقریباً بدون تغییر باقی می‌ماند.

یک توسعه‌دهنده React وب می‌تواند سریع وارد توسعه موبایل با React Native شود، هرچند سرعت یادگیری به تجربه قبلی او از مفاهیم موبایل بستگی دارد.

شیب یادگیری بسیار ملایم است:

ساختار کامپوننت یکی است، جریان داده یکی است؛ فقط خروجی (Render Target) فرق دارد.

این آشنایی یک مشکل بزرگ استخدام را حل می‌کند:

  • توسعه‌دهنده JavaScript زیاد است.
  • اما متخصص حرفه‌ای Swift و Kotlin کم‌یاب است.

مزیت معماری مبتنی بر کامپوننت

معماری مبتنی بر کامپوننت باعث می‌شود کد ماژولار و قابل استفاده مجدد باشد. مثلاً شما یک کامپوننت مثل CartItem را یک‌بار می‌سازید و مطمئن هستید روی هر دو دستگاه، رفتار یکسانی دارد.

همچنین React Native از اکوسیستم آشنای JavaScript پشتیبانی می‌کند، مثل:

  • TypeScript برای ایمنی نوع داده
  • Jest برای تست
  • ESLint برای بررسی کیفیت کد

این فریم‌ورک از اکوسیستم جاوااسکریپتی که از قبل می‌شناسید بهره می‌برد (مثل TypeScript برای ایمنی نوع، Jest برای تست و ESLint برای بررسی کد)؛ بنابراین، اعضای جدید تیم سریع‌تر وارد پروژه می‌شوند و کدبیس برای آن‌ها ناآشنا و غریبه به نظر نمی‌رسد.

۳. هات ریلودینگ و تجربه توسعه‌دهنده

در توسعه سنتی موبایل، معمولاً این چرخه را دارید:

  1. تغییر کد
  2. کامپایل
  3. نصب
  4. اجرای اپ
  5. تکرار دوباره

در اپ‌های Native بزرگ، این فرآیند ممکن است چند دقیقه برای هر تغییر طول بکشد. اما Hot Reloading در React Native این چرخه را به چند ثانیه کاهش می‌دهد؛ تغییرات کد مستقیماً به اپ در حال اجرا تزریق می‌شوند، بدون اینکه وضعیت برنامه (State) از بین برود. کافی است یک قانون flexbox را تغییر دهید، ذخیره کنید و بلافاصله تغییر رابط کاربری را ببینید.

ابزارهای دیباگ

این بازخورد سریع با ابزارهای آشنایی مثل موارد زیر همراه است:

  • Chrome DevTools برای دیباگ
  • React DevTools برای بررسی عملکرد
  • VS Code برای گذاشتن Breakpoint

و معمولاً نیازی نیست هم‌زمان با Xcode و Android Studio کار کنید، مگر زمانی که عمیقاً درگیر کد Native باشید.

چرا این تجربه توسعه مهم است؟

سرعت بالای بازخورد باعث می‌شود:

  • توسعه‌دهندگان بیشتر آزمایش کنند.
  • خطاها را زودتر پیدا کنند.
  • تعاملات نرم‌تر و حرفه‌ای‌تری بسازند.
  • بدون افزایش زمان پروژه، کیفیت بالاتری ارائه دهند.

حتی اگر ذی‌نفعان وسط یک دمو، درخواست تغییر رنگ بدهند، می‌توانید همان لحظه استایل را ویرایش کنید و نتیجه را ببینید.

تجربه کار با React Native باعث می‌شود تیم‌ها بعد از پروژه اول، به استفاده از آن وفادار بمانند.
چون:

  • بازخورد سریع‌تر = توسعه‌دهنده بهره‌ورتر
  • بهره‌وری بیشتر = اپ بهتر
  • اپ بهتر = تحویل به‌موقع و در چارچوب بودجه

کاربردهای React Native چیست؟

React Native زمانی بیشترین کارایی را دارد که بخواهید عملکردی نزدیک به Native داشته باشید، بدون اینکه مجبور شوید دو کدبیس جداگانه برای iOS و Android نگه دارید. در سناریوهای زیر، این فریم‌ورک بیشترین بازدهی را نسبت به هزینه ایجاد می‌کند:

کاربردهای react native

۱. اپلیکیشن‌های موبایل محتوا محور (Content-Driven Apps)

اپ‌هایی مثل شبکه‌های اجتماعی، خبرخوان‌ها و کاتالوگ‌های فروشگاهی، بیشتر زمان خود را صرف دریافت و نمایش لیست‌ها می‌کنند(کاری که React Native با استفاده از کامپوننت‌های اسکرول Native واقعی در iOS و Android به‌خوبی انجام می‌دهد).

برای مثال، Instagram بخش زیادی از فید اصلی خود را به React Native منتقل کرده، بدون اینکه تجربه روان کاربران را از بین ببرد. شرکت‌هایی مثل Walmart، Amazon و Bloomberg هم مسیر مشابهی را طی کرده‌اند و نشان داده‌اند که عملکرد نزدیک به Native برای اپ‌های پرترافیک تجاری و رسانه‌ای کاملاً کافی است.

۲. ابزارهای B2B و سازمانی (Enterprise Tools)

سازمان‌هایی که سرعت ورود به بازار برای‌شان مهم است، بیشترین سود را از React Native می‌برند.

برای نمونه، Shopify مجموعه اپلیکیشن موبایل فروشندگان خود را با React Native بازسازی کرد تا یک تیم واحد بتواند هم‌زمان برای هر دو پلتفرم قابلیت منتشر کند.

وقتی حتی چند هفته تاخیر باعث از دست رفتن درآمد می‌شود، توسعه موازی با Swift و Kotlin تبدیل به یک هزینه اضافی سنگین خواهد شد.

۳. MVP استارتاپ‌ها

استارتاپ‌هایی که در رقابت برای اعتبارسنجی بازار هستند، بیش از هر چیز به سرعت اهمیت می‌دهند.

React Native به شما اجازه می‌دهد:

  • فقط یک‌بار با JavaScript کدنویسی کنید.
  • تفاوت‌های جزئی هر پلتفرم را تنظیم کنید.
  • و چند هفته زودتر به App Store و Google Play برسید.

ویژگی Hot Reload هم چرخه بازخورد در تست کاربران را سریع‌تر می‌کند؛ سرعت توسعه‌ای که حتی می‌تواند تعیین‌کننده جایگاه شما در بازار باشد.

۴. سیستم‌های طراحی چندپلتفرمی (Cross-Platform Design Systems)

اپ‌هایی که نیاز دارند طراحی یکپارچه بین وب و موبایل داشته باشند، React Native را گزینه‌ای بسیار مناسب می‌بینند.

مدل کامپوننتی React به‌راحتی از مرورگر وب به موبایل منتقل می‌شود و باعث می‌شود سیستم طراحی شما یک‌دست باقی بماند. اگر این رویکرد را با یک Headless CMS ترکیب کنید، حتی می‌توانید محتوا را بدون نیاز به انتشار نسخه جدید در اپ‌استورها به‌روزرسانی کنید.

در ترکیب با یک CMS بدون رابط (Headless CMS)، می‌توانید بدون نیاز به تایید اپ‌استورها، محتوای اپ را به‌روزرسانی کنید:

رابط کاربری از طریق ویجت‌های واقعی نیتیو رندر می‌شود و امکاناتی مثل نوتیفیکیشن استاندارد سیستم، مدیریت ژست‌های حرکتی (Gesture)، و کش آفلاین را بدون نیاز به کدنویسی اضافه فراهم می‌کند.

کتابخانه‌هایی مثل Firebase یا React Query به‌راحتی با آن یکپارچه می‌شوند، و معماری جدید (Fabric و TurboModules) همچنان فاصله عملکردی با اپ‌های کاملاً نیتیو را کمتر می‌کند.

اگر در نقشه راه پروژه‌ات انتشار سریع، بهبود سریع‌تر، و مدیریت ساده‌تر چند پلتفرم اولویت دارد، React Native قطعاً ارزش بررسی جدی را دارد.

چه زمانی ری‌ اکت نیتیو انتخاب مناسبی نیست؟

با وجود همه مزایای React Native، محدودیت‌هایی وجود دارد از جمله:

  • اپلیکیشن‌های گرافیکی سنگین: بازی‌های سه‌بعدی (3D) و تجربه‌های واقعیت افزوده (AR) به رندر لحظه‌ای و بسیار سریع نیاز دارند. در این موارد، Bridge latency می‌تواند باعث لگ و ناپیوستگی تصویر شود.
  • پردازش مداوم داده‌های سنسورها: اپ‌هایی که به داده‌های پیوسته سنسورها وابسته‌اند (مثل حرکت، موقعیت یا سلامت)، با سربار پردازش داده مواجه می‌شوند که برای عملیات حساس به زمان قابل قبول نیست.
  • دسترسی به سخت‌افزارهای بسیار جدید: اگر پروژه‌ای نیاز داشته باشد بلافاصله از جدیدترین APIهای دستگاه استفاده کند، معمولاً پیاده‌سازی Native سریع‌تر و به‌موقع‌تر خواهد بود.
  • ترکیب تیم توسعه: اگر یک سازمان از قبل تیم قوی Native داشته باشد، اضافه کردن لایه JavaScript ممکن است هماهنگی تیم را پیچیده‌تر و هزینه مدیریتی را بیشتر کند.

«معماری جدید» با رندرر Fabric و TurboModules این فاصله‌ها را کاهش می‌دهد، اما برای پردازش‌های سنگین و محاسباتی آن‌ها را به‌طور کامل از بین نمی‌برد.

قبل از انتخاب، نیازهای پروژه را دقیق بررسی کنید

از خودتان بپرسید:

  • آیا ۶۰ فریم بر ثانیه (60fps) برای اپ شما حیاتی است؟
  • چقدر سریع به APIهای جدید پلتفرم نیاز دارید؟
  • چه مقدار کد Native اختصاصی باید بنویسید؟

اگر این عوامل نقش اصلی را دارند، بهتر است:

  • یا سراغ توسعه‌ی کاملا Native بروید.
  • یا رویکرد ترکیبی (Hybrid) را انتخاب کنید که بخش‌های حساس به عملکرد را با Swift یا Kotlin پیاده‌سازی کند.

شرکت Airbnb نمونه خوبی از این تصمیم است. آن‌ها قابلیت‌های حساس به عملکرد را دوباره به Native منتقل کردند، اما همچنان از React برای وب استفاده می‌کنند. این نشان می‌دهد که انتخاب ابزار باید بر اساس نیاز واقعی پروژه باشد، نه صرفاً ترند بازار.

پیشنهادی: بوتکمپ فرانت اند با ری‌اکت (React JS)

در نهایت

React Native مشکل «دو بار نوشتن اپ» را حل کرده است. با یک کد JavaScript می‌توانید هم برای iOS و هم برای Android اپ بسازید و در عین حال ویجت‌های واقعی نیتیو هر پلتفرم را نیز دریافت کنید. این فریم‌ورک امکاناتی مثل Hot Reloading، معماری مبتنی بر کامپوننت و بهبود سرعت مستند دارد.

عملکرد React Native روزبه‌روز بهتر می‌شود و گزینه جذابی است، به‌خصوص وقتی پروژه شما نیاز به کد نیتیو بسیار پیچیده ندارد.

برای امتحان کردن آن، ابتدا CLI را نصب کنید، مستندات رسمی را بررسی کنید و یک صفحه ساده بسازید که محتوا را از یک Headless CMS دریافت کند. تجربه عملی همیشه بیشتر از اعداد و بنچمارک‌ها به شما یاد می‌دهد.

منبع: strapi.io

نوشته های مشابه

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

دکمه بازگشت به بالا