ویژگی تصویر

قلاب useMemo در React

  /  React   /  قلاب useMemo در React
بنر تبلیغاتی الف
فریمورک react - کتابخانه react

در این بخش به بررسی قلاب useMemo در React می پردازیم، React به‌عنوان یکی از کتابخانه‌های محبوب جاوا اسکریپت، ابزارهای قدرتمندی را برای ساخت رابط‌های کاربری تعاملی ارائه می‌دهد. در میان این ابزارها، قلاب‌ها (Hooks) نقش کلیدی ایفا می‌کنند، زیرا به توسعه‌دهندگان امکان می‌دهند تا قابلیت‌های پیچیده مانند مدیریت حالت یا بهینه‌سازی عملکرد را به‌راحتی پیاده‌سازی کنند. یکی از این قلاب‌ها، useMemo، به منظور بهینه‌سازی محاسبات سنگین و پیشگیری از اجرای غیرضروری آن‌ها طراحی شده است.

در این مقاله، قصد داریم مفهوم، نحوه استفاده، و اهمیت قلاب useMemo را به‌طور کامل بررسی کنیم. همچنین، با ارائه مثال‌هایی عملی، به شما نشان خواهیم داد که چگونه می‌توانید از این قلاب برای بهبود عملکرد برنامه‌های خود استفاده کنید. اگر به‌دنبال بهینه‌سازی پروژه‌های Reactی خود هستید، این راهنما نقطه شروع بسیار خوبی است.

قلاب useMemo چیست؟

قلاب useMemo یکی از ابزارهای ارائه‌شده توسط React است که در نسخه ۱۶.۸ معرفی شد. هدف اصلی این قلاب جلوگیری از اجرای غیرضروری یک تابع یا محاسبه خاص در هنگام رندر شدن کامپوننت‌هاست. به‌طور خاص، useMemo تضمین می‌کند که یک تابع فقط زمانی دوباره اجرا شود که وابستگی‌های آن تغییر کرده باشند.

تعریف useMemo:

const memoizedValue = useMemo(() => computeExpensiveValue(a, b), [a, b]);

توضیحات کد:

  1. پارامتر اول: یک تابع که نتیجه آن محاسبه و ذخیره می‌شود.
  2. پارامتر دوم: آرایه‌ای از وابستگی‌ها. زمانی که هر یک از این وابستگی‌ها تغییر کنند، تابع مجدد اجرا می‌شود.

چرا useMemo اهمیت دارد؟

در React، هر بار که یک کامپوننت رندر می‌شود، تمام توابع داخل آن اجرا می‌شوند. اگر این توابع شامل محاسبات سنگین یا داده‌های وابسته به تغییرات کمی باشند، می‌تواند باعث کاهش کارایی شود. useMemo این مشکل را با ذخیره نتیجه محاسبات حل می‌کند.

موارد استفاده از useMemo

قلاب useMemo در سناریوهای مختلفی می‌تواند مفید باشد. در ادامه به مهم‌ترین آن‌ها می‌پردازیم:

۱. محاسبات سنگین

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

مثال:
تماشا در حالت تمام صفحه
توضیحات:
  • بدون استفاده از useMemo، تابع expensiveCalculation در هر رندر اجرا می‌شود، حتی اگر ورودی تغییر نکرده باشد.
  • با استفاده از useMemo، این محاسبه فقط زمانی اجرا می‌شود که مقدار num تغییر کند.

۲. جلوگیری از تغییر غیرضروری در اشیاء یا آرایه‌ها

اگر یک کامپوننت مقدار یک شیء یا آرایه را به فرزند خود ارسال کند، ممکن است باعث شود کامپوننت فرزند دوباره رندر شود، حتی اگر داده‌ها تغییر نکرده باشند. useMemo می‌تواند این مشکل را حل کند.

مثال:
تماشا در حالت تمام صفحه
توضیحات:
  • تابع مرتب‌سازی فقط زمانی اجرا می‌شود که آرایه items تغییر کند.
  • این کار باعث کاهش رندرهای غیرضروری در ChildComponent می‌شود.

۳. بهینه‌سازی توابع ناشی از وابستگی

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

مثال:
تماشا در حالت تمام صفحه
توضیحات:
  • داده‌ها فقط زمانی فیلتر می‌شوند که data یا filter تغییر کنند.
  • این کار باعث افزایش کارایی می‌شود، زیرا از اجرای غیرضروری جلوگیری می‌کند.

اشتباهات رایج در استفاده از useMemo

۱. استفاده نادرست در مواقع غیرضروری

گاهی اوقات، توسعه‌دهندگان useMemo را در جاهایی که نیازی به آن نیست، به کار می‌برند. این کار می‌تواند کد را پیچیده‌تر کند بدون اینکه بهبود عملکردی ایجاد کند.

۲. فراموش کردن وابستگی‌ها

اگر وابستگی‌ها به درستی تعریف نشوند، ممکن است محاسبات قدیمی ذخیره شده باقی بمانند و داده‌های نادرستی نمایش داده شود.

مثال اشتباه:
const memoizedValue = useMemo(() => computeExpensiveValue(a, b), []);

در این مثال، محاسبه هرگز به‌روز نمی‌شود، زیرا آرایه وابستگی خالی است.

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

منابع

  • React Documentation: useMemo

آیا این مطلب برای شما مفید بود ؟

خیر
بله
بنر تبلیغاتی ج