Heim > Web-Frontend > js-Tutorial > Wie kann ich sicherstellen, dass Skripte ausgeführt werden, wenn ich „innerHTML' in JavaScript verwende?

Wie kann ich sicherstellen, dass Skripte ausgeführt werden, wenn ich „innerHTML' in JavaScript verwende?

Linda Hamilton
Freigeben: 2024-12-11 10:55:10
Original
872 Leute haben es durchsucht

How Can I Ensure Scripts Execute When Using `innerHTML` in JavaScript?

Mit .innerHTML eingefügte Skripte ausführen

Beim Einfügen von Inhalten in ein Element mithilfe von innerHTML können Probleme auftreten, bei denen Skripte innerhalb des eingefügten Inhalts nicht ausgeführt werden. Es gibt zwar Lösungen, die jQuery oder eval verwenden, hier ist ein Codeausschnitt, der dieses Problem mit reinem JavaScript behebt:

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);
  });
}
Nach dem Login kopieren

Diese Funktion verwendet ein Element und eine HTML-Zeichenfolge als Parameter. Es ersetzt das innerHTML des Elements durch die bereitgestellte Zeichenfolge und durchläuft alle Skriptelemente im HTML. Für jedes Skriptelement wird ein neues mit denselben Attributen und demselben Skripttext erstellt. Schließlich ersetzt es das alte Skriptelement durch das neue.

Um diese Funktion zu verwenden, legen Sie einfach den innerHTML:

.innerHTML = HTML;    // does *NOT* run <script> tags in HTML
setInnerHTML(, HTML); // does run <script> tags in HTML
Nach dem Login kopieren
eines Elements fest

Das obige ist der detaillierte Inhalt vonWie kann ich sicherstellen, dass Skripte ausgeführt werden, wenn ich „innerHTML' in JavaScript verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage