Maison > interface Web > js tutoriel > Pourquoi les scripts dans innerHTML ne s'exécutent-ils pas et comment puis-je y remédier ?

Pourquoi les scripts dans innerHTML ne s'exécutent-ils pas et comment puis-je y remédier ?

Linda Hamilton
Libérer: 2024-12-20 12:43:17
original
887 Les gens l'ont consulté

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

Comment exécuter des scripts insérés à l'aide de innerHTML ?

Lorsque vous utilisez innerHTML pour injecter du contenu dans un élément, les scripts inclus dans le contenu peuvent ne pas être exécuté automatiquement. Cela se produit parce que les navigateurs n'évaluent pas les scripts après leur insertion à l'aide de innerHTML.

Solution :

Pour résoudre ce problème, vous pouvez utiliser JavaScript pour recréer chaque élément de script. manuellement et remplacez les balises de script d'origine dans le DOM. Voici une solution dans 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);
    });
}
Copier après la connexion

Utilisation :

.innerHTML = HTML; // does *NOT* run <script> tags in HTML
setInnerHTML(, HTML); // does run <script> tags in HTML
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal