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
Linda HamiltonOriginal
2024-12-11 10:55:10803Durchsuche

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);
  });
}

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
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!

Stellungnahme:
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
Vorheriger Artikel:React-EntwicklerressourcenNächster Artikel:React-Entwicklerressourcen