Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Menambah Teg Skrip dengan Selamat untuk Komponen Bertindak balas?

Bagaimana untuk Menambah Teg Skrip dengan Selamat untuk Komponen Bertindak balas?

Barbara Streisand
Lepaskan: 2024-12-18 07:09:11
asal
167 orang telah melayarinya

How to Safely Add Script Tags to React Components?

Menambah Tag Skrip ke React/JSX

Dalam React, anda boleh menambah skrip sebaris menggunakan sama ada dangerouslySetInnerHTML atau mencipta elemen skrip dalam kitaran hayat componentDidMount kaedah.

Menggunakan dangerouslySetInnerHTML

membenarkan anda untuk menentukan HTML mentah sebagai rentetan, tetapi penting untuk ambil perhatian bahawa ia harus digunakan dengan berhati-hati kerana ia membuka kelemahan keselamatan. Contohnya:

<script src="https://use.typekit.net/foobar.js"></script>
<script dangerouslySetInnerHTML={{__html: 'try{Typekit.load({ async: true });}catch(e){}'}}></script>
Salin selepas log masuk

Walau bagaimanapun, pendekatan ini mungkin tidak selalu melaksanakan skrip yang diingini.

Mencipta Elemen Skrip dalam componentDidMount

Pertimbangkan perkara berikut:

componentDidMount () {
    const script = document.createElement("script");

    script.src = "https://use.typekit.net/foobar.js";
    script.async = true;

    document.body.appendChild(script);
}
Salin selepas log masuk

Kaedah ini memasukkan skrip secara dinamik ke dalam DOM apabila komponen dipasang.

Pendekatan Disyorkan: Menggunakan Pakej npm

Sebelum menggunakan skrip sebaris, adalah disyorkan untuk menyemak sama ada pra -pakej npm terbina tersedia untuk skrip yang anda ingin muatkan. Sebagai contoh, jika anda ingin memuatkan Typekit, anda boleh memasang pakej typekit dan mengimportnya seperti:

import Typekit from 'typekit';
Salin selepas log masuk

Kemas kini: Menggunakan useEffect Hook

Dengan pengenalan cangkuk, anda boleh menggunakan useEffect untuk memuatkan lebih banyak skrip dengan cekap:

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);
  }
}, []);
Salin selepas log masuk

Anda juga boleh membungkus logik ini ke dalam cangkuk tersuai untuk kebolehgunaan semula yang mudah.

Atas ialah kandungan terperinci Bagaimana untuk Menambah Teg Skrip dengan Selamat untuk Komponen Bertindak balas?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan