
本文旨在解决 React 应用中无法直接通过 JSX 嵌入外部 script 标签的问题。由于 React 使用 innerHTML 来操作 DOM,出于安全考虑,直接插入的 script 标签不会被执行。本文将介绍如何利用 useEffect hook 在 React 组件中动态加载和卸载外部 JavaScript 文件,以实现嵌入外部 script 标签的功能。
在 React 应用中,直接将包含 <script> 标签的 HTML 代码嵌入到 JSX 中,通常无法正常执行。这是因为 React 使用 innerHTML 来更新 DOM,而 innerHTML 默认会阻止 script 标签的执行,以防止潜在的安全问题。
为了解决这个问题,我们可以使用 useEffect hook 来动态地创建和添加 script 标签到 DOM 中。useEffect 允许我们在组件挂载后执行副作用操作,例如添加外部脚本。
以下是一个示例,展示了如何在 React 组件中动态加载 GoFundMe 的嵌入脚本:
import React, { useEffect } from 'react';
const Donation = () => {
useEffect(() => {
const script = document.createElement('script');
script.src = "https://www.gofundme.com/static/js/embed.js";
script.async = true; // 异步加载,避免阻塞页面渲染
document.body.appendChild(script);
// 组件卸载时移除 script 标签,避免内存泄漏
return () => {
document.body.removeChild(script);
};
}, []); // 空依赖数组,确保 useEffect 只在组件挂载和卸载时执行
return (
<div>
<div className="gfm-embed" data-url="https://www.gofundme.com/f/theyre-the-real-victims/widget/large/"></div>
</div>
);
};
export default Donation;代码解释:
通过使用 useEffect hook,我们可以方便地在 React 组件中动态加载和卸载外部 script 标签。这种方法避免了直接使用 innerHTML 带来的问题,并提供了更好的控制和灵活性。记住要异步加载脚本,并提供清理函数来避免内存泄漏。
以上就是在 React 应用中嵌入外部 Script 标签的正确方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号