在React jsx中的script-tag内执行javascript代码
我将此脚本标签添加到我的 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 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您可以通过 npm 包添加它。我将其用作(一次):
这是 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 ):
Here is the npm package link https://www.npmjs.com/package/react-script-tag
删除
标签并替换为
{}
。所以:
{alert('Hello world')}
Remove the
<script>
tag and replace with{}
.So:
{alert('Hello world')}