حلقه در JSX ری‌اکت

mohsen1 سال قبل1 سال قبل
ارسال شده در
react

در ری‌اکت، اگر بخواهید یک کامپوننت (مانند ObjectRow) را چندین بار اضافه کنید، استفاده از حلقه‌ها به صورت مستقیم در JSX مجاز نیست. به جای آن، شما می‌توانید از توابع جاوااسکریپت مانند map یا روش‌های دیگر برای ساخت آرایه‌ از کامپوننت‌ها استفاده کنید.

یکی از راه‌های معمول برای تکرار یک کامپوننت، استفاده از map بر روی یک آرایه است. اگر شما قبلاً یک آرایه دارید، می‌توانید آن را به صورت زیر متناسب کنید:

      <tbody>
    {objects.map((object, i) => <ObjectRow obj={object} key={i} />)}
</tbody>
    

اگر به دنبال ایجاد تعدادی ردیف بدون وجود آرایه اولیه هستید، می‌توانید از توابع جاوااسکریپت همراه با Array برای تولید آرایه استفاده کنید. به عنوان مثال:

      <tbody>
  {[...Array(numrows)].map((_, i) => <ObjectRow key={i} />)}
</tbody>
    

در این کد Array(numrows) یک آرایه خالی تشکیل می‌دهد و سپس با استفاده از map، یک کامپوننت ObjectRow برای هر عنصر آرایه تولید می‌کند. این روش به شما کمک می‌کند تا بدون استفاده از یک حلقه for، خروجی خود را به سادگی تولید کنید.

همچنین می‌توانید از Array.apply یا Array.fill برای تولید آرایه‌های مشابه استفاده کنید:

      <tbody>
  {Array(10).fill().map((_, i) => <ObjectRow key={i} />)}
</tbody>
    

همچنین، در هنگام تولید کامپوننت‌های تکراری، به فراموش نکردن پارامتر key که برای شناسایی یکتای عناصر ضروری است، توجه کنید. این کار باعث می‌شود ری‌اکت بتواند به راحتی تغییرات را مدیریت کند و بهینه‌سازی‌هایی انجام دهد.

رای
0
ارسال نظر
مرتب سازی:
اولین نفری باشید که نظر می دهید!