在React jsx中的script-tag内执行javascript代码

发布于 2025-01-15 01:20:52 字数 1047 浏览 3 评论 0原文

我将此脚本标签添加到我的 React jsx 渲染中:

<script>alert('Hello world')</script>

为什么 Javascript 代码 未在我的 React 应用程序中执行?

更新:

我正在调试这个,因为我从 api 返回了这个 HTML:

<div class="my-class" data-src="/event/66478667"></div>
<script>(function(d, s, id) {var js,ijs=d.getElementsByTagName(s)[0];if(d.getElementById(id))return;js=d.createElement(s);js.id=id;js.src="https://embed.widget.js";ijs.parentNode.insertBefore(js, ijs);}(document, 'script', 'my-js'));</script>

现在我通过 html-react-parser 包如下:

return <div data-testid="html-paragraph">{parser(html)}</div>;

但这不起作用,因为 Javascript 代码没有执行?

怎么解决这个问题呢?

请参阅此处我的代码沙箱

I am adding this script-tag to my React jsx render:

<script>alert('Hello world')</script>

Why is the Javascript code <script>alert('Hello world')</script> not executing in my React app?

Update:

I am debugging this because I get this HTML back from api:

<div class="my-class" data-src="/event/66478667"></div>
<script>(function(d, s, id) {var js,ijs=d.getElementsByTagName(s)[0];if(d.getElementById(id))return;js=d.createElement(s);js.id=id;js.src="https://embed.widget.js";ijs.parentNode.insertBefore(js, ijs);}(document, 'script', 'my-js'));</script>

Now I am parsing this HTML through html-react-parser package like:

return <div data-testid="html-paragraph">{parser(html)}</div>;

But this isn't working because the Javascript code isn't executing?

How to solve this?

See here my code sandbox.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

千柳 2025-01-22 01:20:52

您可以通过 npm 包添加它。我将其用作(一次):

import React, { Component } from 'react';
import ScriptTag from 'react-script-tag';
 
class Demo extends Component {
 
    render() {
        return (<ScriptTag isHydrating={true} type="text/javascript" src="some_script.js" />);
    }
}

这是 npm 包链接 https://www.npmjs.com/package/react-script-tag" rel="nofollow noreferrer">https://www.npmjs.com npmjs.com/package/react-script-tag

You can add it via npm package. I used it as ( once ):

import React, { Component } from 'react';
import ScriptTag from 'react-script-tag';
 
class Demo extends Component {
 
    render() {
        return (<ScriptTag isHydrating={true} type="text/javascript" src="some_script.js" />);
    }
}

Here is the npm package link https://www.npmjs.com/package/react-script-tag

死开点丶别碍眼 2025-01-22 01:20:52

删除

所以:{alert('Hello world')}

Remove the <script> tag and replace with {}.

So: {alert('Hello world')}

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文