首页 >web前端 >js教程 >为什么innerHTML 中的脚本不执行,如何修复?

为什么innerHTML 中的脚本不执行,如何修复?

Linda Hamilton
Linda Hamilton原创
2024-12-20 12:43:17884浏览

Why Don't Scripts in innerHTML Execute, and How Can I Fix It?

如何执行使用innerHTML插入的脚本?

当使用innerHTML将内容注入到元素中时,内容中包含的脚本可能不会被执行自动执行。出现这种情况是因为浏览器在使用innerHTML插入脚本后不会对其进行评估。

解决方案:

要解决此问题,您可以使用 JavaScript 重新创建每个脚本元素手动并替换 DOM 中的原始脚本标签。这是 ES6 中的解决方案:

function setInnerHTML(elm, html) {
  elm.innerHTML = html;

  Array.from(elm.querySelectorAll("script"))
    .forEach(oldScriptEl => {
      const newScriptEl = document.createElement("script");

      Array.from(oldScriptEl.attributes).forEach(attr => {
        newScriptEl.setAttribute(attr.name, attr.value);
      });

      const scriptText = document.createTextNode(oldScriptEl.innerHTML);
      newScriptEl.appendChild(scriptText);

      oldScriptEl.parentNode.replaceChild(newScriptEl, oldScriptEl);
    });
}

用法:

.innerHTML = HTML; // does *NOT* run <script> tags in HTML
setInnerHTML(, HTML); // does run <script> tags in HTML

以上是为什么innerHTML 中的脚本不执行,如何修复?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn