پیشنهاد شگفت‌انگیز سبزلرن: 50% تخفیف برای دوره پروژه های تخصصی با جاوا اسکریپت برای بازار کار
مشاهده دوره
ثانیه
دقیقه
ساعت
روز
پرسش

افزودن تگ به JSX در React

Adding script tag to React JSX

من دارم از React استفاده می‌کنم و می‌خوام یک تگ <script> توی فایل JSX قرار بدم. اما هر کاری می‌کنم، تگ درست اجرا نمیشه و مشکل ایجاد میشه.
می‌خواستم بدونم چطور می‌تونم به درستی یک تگ <script> رو توی JSX اضافه کنم؟ ممنون میشم راهنمایی کنید.

1403/06/02
پاسخ
محمدامین سعیدی راد
بیوگرافی محمدامین سعیدی راد

مشکل اضافه کردن تگ <script> توی JSX اینه که React با dangerouslySetInnerHTML کار می‌کنه و به طور کلی از تگ‌های <script> در JSX پشتیبانی نمی‌کنه. اگه بخوای یه اسکریپت خارجی رو به پروژه Reactت اضافه کنی، بهترین روش اینه که از فایل‌های public/index.html استفاده کنی یا اگه بخوای به صورت داینامیک اسکریپت اضافه کنی، می‌تونی از جاوااسکریپت برای این کار کمک بگیری.

راه‌حل پیشنهادی:

اضافه کردن به public/index.html:
اگه اسکریپتت نیازی نداره که حتماً داخل کامپوننت React باشه و فقط می‌خوای به کل اپلیکیشن دسترسی داشته باشه، می‌تونی به راحتی تگ <script> رو توی فایل public/index.html اضافه کنی. این فایل در روت پروژه قرار داره و وقتی اپلیکیشن لود میشه، این اسکریپت هم به صورت خودکار لود میشه.

<!-- public/index.html -->
<script src="your-script-url.js"></script>

۲. اضافه کردن به صورت داینامیک داخل یک کامپوننت React:
اگه نیاز داری اسکریپتت به صورت داینامیک داخل یک کامپوننت React اضافه بشه (مثلاً بعد از اینکه کامپوننت لود شد)، می‌تونی از این روش استفاده کنی:

import { useEffect } from 'react';
function MyComponent() {
 useEffect(() => {
   const script = document.createElement('script');
   script.src = 'your-script-url.js';
   script.async = true;
   document.body.appendChild(script);
  
   return () => {
   document.body.removeChild(script);
};
}, []);
 return (
   <div>
    {/* Your component code */}
   </div>
);
}
export default MyComponent;

توی این روش، از هوک useEffect استفاده می‌کنیم تا وقتی کامپوننت رندر شد، اسکریپت رو به صورت داینامیک به بدنه صفحه اضافه کنیم. این کار تضمین می‌کنه که اسکریپت فقط زمانی که کامپوننت موجوده، اجرا بشه.

نکته: این روش رو فقط زمانی استفاده کن که واقعاً نیاز به اضافه کردن اسکریپت به کامپوننت داری و نمیتونی از روش اول استفاده کنی.

نتیجه‌گیری:

برای اضافه کردن اسکریپت به یک پروژه React، بهترین روش اینه که از public/index.html استفاده کنی یا اگه نیاز به اضافه کردن اسکریپت به صورت داینامیک داخل کامپوننت داری، از روش دوم استفاده کنی. اینطوری، کدت تمیزتر می‌مونه و با معماری React هم هماهنگه.

پاسخ: 1403/06/02
آخرین آپدیت: 1403/07/25