首頁 > web前端 > js教程 > 如何安全且有效率地為React元件新增腳本標籤?

如何安全且有效率地為React元件新增腳本標籤?

Mary-Kate Olsen
發布: 2024-12-20 04:22:13
原創
474 人瀏覽過

How to Safely and Efficiently Add Script Tags to React Components?

在 React/JSX 中加入腳本標籤

本題的目標是探索在 React 元件中加入內聯腳本的方法。使用者嘗試使用內聯腳本標籤和angerlySetInnerHTML屬性來載入外部腳本,但這兩種方法似乎都無法執行所需的腳本。

建議的一個解決方案是在React元件中建立一個componentDidMount方法並動態建立建立腳本元素並將其附加到 DOM。這種方法確保腳本在元件安裝時僅執行一次。

但是,React 中更現代和推薦的方法是使用 useEffect 鉤子。此鉤子可讓您在元件渲染後執行副作用,例如進行 API 呼叫或操作 DOM。

以下程式碼片段示範如何使用useEffect 載入腳本:

useEffect(() => {
  const script = document.createElement('script');
  script.src = 'https://use.typekit.net/foobar.js';
  script.async = true;
  document.body.appendChild(script);

  return () => {
    document.body.removeChild(script);
  }
}, []);
登入後複製

透過將此程式碼包裝在自訂掛鉤中,它可以在多個元件中重複使用:

const useScript = url => {
  useEffect(() => {
    const script = document.createElement('script');
    script.src = url;
    script.async = true;
    document.body.appendChild(script);

    return () => {
      document.body.removeChild(script);
    }
  }, [url]);
};
登入後複製

可以用作如下圖:

import useScript from 'hooks/useScript';

const MyComponent = props => {
  useScript('https://use.typekit.net/foobar.js');

  // Rest of the component
}
登入後複製

將useEffect鉤子與自訂腳本鉤子結合使用,提供了一種在 React 元件中載入和執行腳本的乾淨高效的方法。

以上是如何安全且有效率地為React元件新增腳本標籤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板