blanks Blog: http://www.planabc.net/ Die Verwendung des
innerHTML-Attributs erfreut sich großer Beliebtheit, da es eine einfache Möglichkeit bietet, den Inhalt eines HTML-Elements vollständig zu ersetzen. Eine andere Methode ist die Verwendung der DOM Level 2 API (removeChild, createElement, appendChild). Aber offensichtlich ist die Verwendung von innerHTML zum Ändern des DOM-Baums eine sehr einfache und effektive Methode. Sie müssen sich jedoch darüber im Klaren sein, dass innerHTML einige eigene Probleme hat:
-
Wenn eine HTML-Zeichenfolge ein Skript-Tag (
- Es gibt noch einige weitere kleinere Nachteile, die ebenfalls erwähnenswert sind:
Ich mache mir mehr Sorgen über die Sicherheits- und Speicherprobleme, die mit der Verwendung des innerHTML-Attributs verbunden sind. Offensichtlich ist dies kein neues Problem, und es gibt bereits talentierte Leute, die Lösungen für einige dieser Probleme gefunden haben.
Douglas Crockford hat eine Bereinigungsfunktion geschrieben, die dafür verantwortlich ist, einige Zirkelverweise zu unterbrechen, die durch die Registrierung von Ereignishandlern durch HTML-Elemente verursacht werden, und die es dem Garbage Collector ermöglicht, den mit diesen HTML-Elementen verbundenen Speicher freizugeben.
Das Entfernen von Skript-Tags aus HTML-Strings ist nicht so einfach, wie es aussieht. Ein regulärer Ausdruck kann den gewünschten Effekt erzielen, allerdings ist es schwierig zu wissen, ob er alle Möglichkeiten abdeckt. Hier ist meine Lösung: <script>/</script>[^>]*>[Ss]*?]*>/ig
Jetzt kombinieren wir diese beiden Techniken in einer einzigen setInnerHTML-Funktion und binden die setInnerHTML-Funktion an YAHOO.util.Dom von YUI:
YAHOO.util.Dom.setInnerHTML = function (el, html) {
el = YAHOO.util.Dom.get(el);
if (!el || typeof html !== 'string ') {
return null;
}
// Zirkelverweis abbrechen
(Funktion (o) {
var a = o.attributes, i, l, n, c;
if (a) {
l = a.length; for (i = 0; i n = a[i].name;
if (typeof o[n] === 'function') {
o[n] = null;
}
}
}
a = o.childNodes;
if (a) {
l = a.length; for (i = 0; i c = o.childNodes[i];
// Untergeordnete Knoten löschen
arguments.callee(c);
// Alle über YUIs addListener für das Element registrierten Listener entfernen
YAHOO.util.Event.purgeElement(c);
}
}
})(el);
// Skript aus der HTML-Zeichenfolge entfernen und das innerHTML-Attribut festlegen <script> el.innerHTML = html.replace(/</script>[^>]*>[Ss]*?
]*>/ig, " ");
// Gibt die Referenz des ersten untergeordneten Knotens zurück
return el.firstChild;
};
Wenn diese Funktion noch etwas tun soll oder etwas im regulären Ausdruck fehlt, lassen Sie es mich bitte wissen. <script>Natürlich gibt es viele andere Möglichkeiten, schädlichen Code in Webseiten einzuschleusen. Die setInnerHTML-Funktion normalisiert nur das Ausführungsverhalten des <br />-Tags in allen Browsern der Klasse A. Wenn Sie nicht vertrauenswürdigen HTML-Code einfügen möchten, müssen Sie ihn zuerst auf der Serverseite filtern. Es gibt viele Bibliotheken, die dies tun können. <script defer>…</script>Originaltext: „The Problem With innerHTML“ von Julien Lecomte

HTML ist eine Sprache, mit der Webseiten erstellt, die Webseitenstruktur und -inhalt über Tags und Attribute definiert werden. 1) HTML organisiert die Dokumentstruktur über Tags, wie z. B.. 2) Der Browser analysiert HTML, um das DOM zu erstellen und die Webseite zu rendern. 3) Neue Merkmale von HTML5, wie z. B. Multimedia -Funktionen. 4) Zu den häufigen Fehlern gehören nicht abgestimmte Bezeichnungen und nicht geeignete Attributwerte. 5) Die Optimierungsvorschläge umfassen die Verwendung semantischer Tags und die Reduzierung der Dateigröße.

WebdevelopmentRelieSonHtml, CSS und JavaScript: 1) HtmlStructuresContent, 2) CSSstylesit und 3) JavaScriptaddssinteraktivität, Bildung von TheBasisofModerernwebexperiences.

Die Rolle von HTML besteht darin, die Struktur und den Inhalt einer Webseite durch Tags und Attribute zu definieren. 1. HTML organisiert Inhalte über Tags wie das Lesen und Verständnis. 2. Verwenden Sie semantische Tags wie usw., um die Zugänglichkeit und SEO zu verbessern. 3. Optimierung des HTML -Codes kann die Ladegeschwindigkeit und die Benutzererfahrung der Webseite verbessern.

HtmlisaspecifictypeofcodeFocusedonstructuringuringwebcontent, während "Code" breitincludesluages -ähnlichjavaScriptandpythonforfunctionality.1) htmldefineswebpageStructureStags.2) "Code" cometesaWiNrangeOfLanguagesForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForForfirsInsForfunctionNacts

HTML, CSS und JavaScript sind die drei Säulen der Webentwicklung. 1. HTML definiert die Webseitenstruktur und verwendet Tags wie z.

HTML definiert die Webstruktur, CSS ist für Stil und Layout verantwortlich, und JavaScript ergibt eine dynamische Interaktion. Die drei erfüllen ihre Aufgaben in der Webentwicklung und erstellen gemeinsam eine farbenfrohe Website.

HTML ist für Anfänger geeignet, da es einfach und leicht zu lernen ist und schnell Ergebnisse sehen kann. 1) Die Lernkurve von HTML ist glatt und leicht zu beginnen. 2) Beherrschen Sie einfach die grundlegenden Tags, um Webseiten zu erstellen. 3) hohe Flexibilität und kann in Kombination mit CSS und JavaScript verwendet werden. 4) Reiche Lernressourcen und moderne Tools unterstützen den Lernprozess.

AnexampleofaTartingTaginHtmlis, die, die starttagsaresesinginhtmlastheyinitiateElements, definetheirtypes, andarecrucialForstructuringwebpages und -konstruktionsthedoms.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen