Heim Web-Frontend js-Tutorial Kompatibilitäts- und fehleranfällige Probleme, die in js leicht auftreten

Kompatibilitäts- und fehleranfällige Probleme, die in js leicht auftreten

Jun 20, 2018 pm 02:55 PM
js 兼容性

Der folgende Editor wird mit Ihnen einen Artikel teilen, der einige Kompatibilitäts- und fehleranfällige Probleme in js zusammenfasst. Er hat einen guten Referenzwert und ich hoffe, dass er für alle hilfreich sein wird. Folgen wir dem Editor und werfen wir einen Blick darauf tatsächlich unterschiedliche Konzepte.

Merkmale (Attribute) werden im HTML-Text angezeigt, Änderungen an Attributen werden definitiv im äußeren HTML von Elementen angezeigt und Attribute existieren nur in Elementknoten;Eigenschaften werden verwendet Mit Ausnahme einiger integrierter Funktionen des Browsers wirken sich andere Eigenschaftsvorgänge nicht auf HTML-Text aus.

1. IE6/7 unterscheidet nicht zwischen Attributen und Merkmalen

Andere Browser unterscheiden nicht zwischen Attributen und Merkmalen, aber IE67 unterscheidet nicht zwischen ihnen Nur Features können mithilfe von Attributnamen gelöscht werden. Obwohl diese beiden Namen oft gleich sind, gibt es immer Unterschiede.

2. IE6/7 kann getAttribute/setAttribute nicht verwenden, um Funktionen zu bedienen, deren Wert kein String ist

In modernen Browsern gibt getAttribute definitiv den entsprechenden Wert in HTML zurück String, und das von IE67 zurückgegebene Ergebnis ist unvorhersehbar. Daher müssen wir unter IE67 AttributeNode verwenden, um Attribute zu bedienen.

3. IE6/7/8 kann CSS-Text nicht über das Stilattribut abrufen

Dieses Problem sollte die Folge davon sein, dass IE6/7 nicht zwischen Attributen und Merkmalen unterscheidet. Wenn Sie das style-Attribut verwenden, verwenden Sie einfach elem.style.cssText.

4. IE6/7 analysiert relative URLs in absolute URLs

Dieses Problem führt sogar dazu, dass das leere src-Attribut unter IE6/7 doppelte Anfragen generiert getAttribute('href/src', 4).

Das Standardverhalten von Elementfunktionen ist unterschiedlich.

In einigen alten Webkit-Browsern gibt es beispielsweise viele Fehler checkbox/radio Der Wert ist „“, nicht aktiviert. In einigen älteren Webkit-Browsern wird das erste Element der Auswahl nicht ausgewählt.

2. Stiloperationen

Normalerweise umfassen Stile das Abrufen und Festlegen von Inline-Stilen und das Abrufen berechneter Stile von Elementen

1. IE unterstützt Hintergrundposition-x/y, andere Browser jedoch nicht. Hintergrundposition-x/y kann verwendet werden, um die Position eines Bildes bequem zu ändern Da dies nicht unterstützt wird, können wir erwägen, das Parsing-Attribut „background-position“ zu verwenden, um damit umzugehen.

2. IE6/7 unterstützt das Opazitätsattribut nicht

Sie können den gleichen Effekt durch einen Alphafilter erzielen, denken Sie jedoch daran, das Haslayout des Elements auszulösen.

3. IE6/7/8 lässt fälschlicherweise zu, dass die vom Klon generierten Knoten einige Attribute erben.

Wenn Sie beispielsweise ein oder zwei Attribute ändern, werden sie dies tun gleichzeitig geändert werden.

4. Verschiedene Möglichkeiten, den berechneten Stil zu erhalten

IE6/7/8 verwendet elem.currentStyle, während andere Browser die Funktion window.getComputedStyle verwenden.

5. Verschiedene Pixelierungsmethoden

Pixelisierung bezieht sich auf die Umwandlung von Abständen, deren Einheiten keine Pixel sind, in Pixel, um Berechnungen zu erleichtern. Streng genommen handelt es sich hierbei nicht um ein Kompatibilitätsproblem, es kann jedoch allgemein verwendet werden. In IE6/7/8 können wir elem.runtimeStyle mit pixelLeft zur Verarbeitung verwenden.

Moderne Browser können das width-Attribut verwenden.

6. Einige BUG-Verhaltensweisen beim Abrufen von CSS

In Webkti-Kernbrowsern geht Margin-Right oft schief.

3. Abfrageoperation

Abfrageübergabe bezieht sich auf das Finden einer Reihe von Elementen anhand einiger charakteristischer Zeichenfolgen oder auf die Beurteilung, ob die Elemente Zeichenfolge erfüllen.

1. IE6/7 unterscheidet nicht zwischen ID und NameBei Verwendung von getElementById und getElementsByName unter IE6/7 wird dieselbe ID oder derselbe Name zurückgegeben gegebener Wert gleichzeitig. Da der Name normalerweise vom Backend vereinbart wird, sollten wir beim Schreiben von JS sicherstellen, dass die ID den Namen nicht dupliziert.

2. IE6/7 unterstützt getElementsByClassName und querySelectorAll nicht

Diese beiden Funktionen werden von IE8 unterstützt, daher können wir sie unter IE6/7 tatsächlich nur getElementByTagName verwenden .

3. IE6/7 unterstützt getElementsByTagName('*') nicht, wodurch Nicht-Element-Knoten zurückgegeben werden.

Verwenden Sie entweder kein * oder schreiben Sie eine Funktion um es selbst zu filtern.

4. querySelectorAll unter IE8 ist nicht für Attributselektoren geeignet

Bei fast allen im Browser vordefinierten Attributen gibt es Probleme.

5. querySelectorAll unterstützt keine Pseudoklassen unter IE8

Manchmal sind Pseudoklassen sehr nützlich, aber IE8 unterstützt sie nicht :first, : last, :even, :odd, :eq, :nth, :lt, :gt sind keine Pseudoklassen und wir sollten sie zu keinem Zeitpunkt verwenden.

6. Die Match-Funktion von IE9 kann keine Elemente verarbeiten, die sich nicht im DOM-Baum befinden.

Solange sich das Element nicht im DOM-Baum befindet, wird dies auf jeden Fall der Fall sein return false. Es ist wirklich unmöglich, das Element nach dem Abgleich im Körper zu löschen. Natürlich können wir auch unsere eigene Abgleichsfunktion schreiben, um einen Rückfluss zu vermeiden.

4. Veranstaltungsbetrieb

Wenn Leute nach der Kompatibilität von JS fragen, ist die erste Reaktion normalerweise attachmentEvent und addEventListener, aber es gibt immer noch viele Details über den Unterschied zwischen diesen beiden Funktionen.

1. Die Ereignisobjekte sind unterschiedlich

addEventListener ist das aktuelle Objekt, zu dem das Ereignis sprudelt, während attachmentEvent ein Fenster ist.

. Die Ereignisparameterobjekte sind unterschiedlich.

Beachten Sie, dass die an attachmentEvent gebundene Funktion nicht e = e || schreibt die beiden. Unterschiede, wie z. B. Schaltfläche oder Hexe, ob pageY unterstützt wird oder nicht usw.

2. Das böse Rad-Event

Die Unterstützung für Rad-Events ist ein Chaos, die Regeln sind wie folgt:
IE6-11 Chrome Mousewheel WheelDetla down- 120 nach oben 120

Firefox DOMMouseScroll Detail nach unten 3 nach oben-3

Firefox Wheel DetlaY nach unten 3 nach oben-3

IE9-11 Wheel DeltaY nach unten 40 nach oben-40

Chrome Wheel Delta Lower 100 Upper -100

Drei große Nicht-Blasen-Ereignisse

Die Fokus-/Unschärfe-Ereignisse aller Browser treten glücklicherweise nicht auf Die meisten Browser unterstützen Focusin/Focusout-Ereignisse, aber der verdammte Firefox unterstützt dies nicht einmal.

Das Submit-Ereignis wird unter IE678 nicht angezeigt.

Unter IE678 wird das Änderungsereignis erst ausgelöst, wenn es verschwimmt.

Und wir haben keine wirksamen Mittel, um diese drei Probleme zu lösen, wir können sie nur durch Simulationsauslösung lösen.

4. a.click()

Diese Methode ist in vielen Browsern nicht sicher, auch wenn das Standardverhalten blockiert ist . .

5. Knotenoperationen

Knotenoperationen beziehen sich normalerweise auf das Kopieren, Generieren eines Knotens oder das Verschieben der Position eines Knotens.

1.. innerHTML

Wenn IE6/7/8 innerHTML verwendet, muss ein Textknoten davor stehen, sonst gehen viele Tags verloren. Darüber hinaus führt die Verwendung von innerHTML in vielen Fällen zu Fehlern im Attribut defaultValue.

2. Nutzloser Tbody

IE6/7/8 fügt automatisch einen leeren Tbody zu einer leeren Tabelle hinzu

3 , wird das attachmentEvent-Ereignis

kopiert und wenn wir die von uns gebundenen Ereignisse nicht aufzeichnen, können wir die Bindung nicht aufheben.

Ich habe das Obige für Sie zusammengestellt und hoffe, dass es Ihnen in Zukunft hilfreich sein wird.

Verwandte Artikel:

So erstellen Sie ein Baummenü durch rekursive Komponenten in Vue.js

So verwenden Sie JSONAPI in PHP

So erreichen Sie eine extrem schnelle Zero-Configuration-Verpackung in Parcel.js + Vue 2.x

Bei Verwendung von Vue kann die Browserunterstützung nicht ausgelöst werden beforeRouteLeave-Problem

So lösen Sie den Tap „Click Through“ im Fastclick-Code

Das obige ist der detaillierte Inhalt vonKompatibilitäts- und fehleranfällige Probleme, die in js leicht auftreten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Vergleich und Differenzanalyse der Versionen Bluetooth 5.3 und 5.2 Vergleich und Differenzanalyse der Versionen Bluetooth 5.3 und 5.2 Dec 28, 2023 pm 06:08 PM

Heutzutage behaupten viele Mobiltelefone, die Bluetooth 5.3-Version zu unterstützen. Was ist also der Unterschied zwischen Bluetooth 5.3 und 5.2? Tatsächlich handelt es sich im Wesentlichen um nachfolgende aktualisierte Versionen von Bluetooth 5, und es gibt keinen großen Unterschied in den meisten Leistungen und Funktionen. Der Unterschied zwischen Bluetooth 5.3 und 5.2: 1. Datenrate 1 und 5.3 können höhere Datenraten bis zu 2 Mbit/s unterstützen. 2. Während 5.2 nur maximal 1 Mbit/s erreichen kann, bedeutet dies, dass 5.3 Daten schneller und stabiler übertragen kann. 2. Verbesserung der Verschlüsselungskontrolle 2. Bluetooth 5.3 verbessert die Optionen zur Kontrolle der Länge des Verschlüsselungsschlüssels, erhöht die Sicherheit und kann eine bessere Verbindung zur Zugangskontrolle und anderen Geräten herstellen. 3. Da die Administratorsteuerung einfacher ist, ist es gleichzeitig bequemer und schneller, eine Verbindung herzustellen, was in 5.2 nicht der Fall ist.

Lösung für i7-7700, kein Upgrade auf Windows 11 möglich Lösung für i7-7700, kein Upgrade auf Windows 11 möglich Dec 26, 2023 pm 06:52 PM

Die Leistung des i77700 reicht völlig aus, um Win11 auszuführen, aber Benutzer stellen fest, dass ihr i77700 nicht auf Win11 aktualisiert werden kann. Dies ist hauptsächlich auf die von Microsoft auferlegten Einschränkungen zurückzuführen, sodass sie es installieren können, solange sie diese Einschränkung überspringen. i77700 kann nicht auf win11 aktualisiert werden: 1. Weil Microsoft die CPU-Version begrenzt. 2. Nur die Intel-Versionen der achten Generation und höher können direkt auf Win11 aktualisiert werden. 3. Als 7. Generation kann der i77700 die Upgrade-Anforderungen von Win11 nicht erfüllen. 4. Der i77700 ist jedoch hinsichtlich der Leistung durchaus in der Lage, Win11 reibungslos zu nutzen. 5. Sie können also das Win11-Direktinstallationssystem dieser Site verwenden. 6. Nachdem der Download abgeschlossen ist, klicken Sie mit der rechten Maustaste auf die Datei und „laden“ sie. 7. Doppelklicken Sie, um den „One-Click“-Vorgang auszuführen

Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Apr 03, 2024 am 11:55 AM

Die Technologie zur Gesichtserkennung und -erkennung ist bereits eine relativ ausgereifte und weit verbreitete Technologie. Derzeit ist JS die am weitesten verbreitete Internetanwendungssprache. Die Implementierung der Gesichtserkennung und -erkennung im Web-Frontend hat im Vergleich zur Back-End-Gesichtserkennung Vor- und Nachteile. Zu den Vorteilen gehören die Reduzierung der Netzwerkinteraktion und die Echtzeiterkennung, was die Wartezeit des Benutzers erheblich verkürzt und das Benutzererlebnis verbessert. Die Nachteile sind: Es ist durch die Größe des Modells begrenzt und auch die Genauigkeit ist begrenzt. Wie implementiert man mit js die Gesichtserkennung im Web? Um die Gesichtserkennung im Web zu implementieren, müssen Sie mit verwandten Programmiersprachen und -technologien wie JavaScript, HTML, CSS, WebRTC usw. vertraut sein. Gleichzeitig müssen Sie auch relevante Technologien für Computer Vision und künstliche Intelligenz beherrschen. Dies ist aufgrund des Designs der Webseite erwähnenswert

Wie kompatibel ist die Go-Sprache auf Linux-Systemen? Wie kompatibel ist die Go-Sprache auf Linux-Systemen? Mar 22, 2024 am 10:36 AM

Die Go-Sprache ist auf Linux-Systemen sehr gut kompatibel. Sie kann problemlos auf verschiedenen Linux-Distributionen ausgeführt werden und unterstützt Prozessoren unterschiedlicher Architekturen. In diesem Artikel wird die Kompatibilität der Go-Sprache auf Linux-Systemen vorgestellt und ihre leistungsstarke Anwendbarkeit anhand spezifischer Codebeispiele demonstriert. 1. Installieren Sie die Go-Sprachumgebung auf einem Linux-System. Sie müssen lediglich das entsprechende Go-Binärpaket herunterladen und die relevanten Umgebungsvariablen festlegen. Im Folgenden finden Sie die Schritte zur Installation der Go-Sprache auf einem Ubuntu-System:

Kann ich Bluetooth-Kopfhörer im Flugzeugmodus verwenden? Kann ich Bluetooth-Kopfhörer im Flugzeugmodus verwenden? Feb 19, 2024 pm 10:56 PM

Mit der kontinuierlichen Weiterentwicklung moderner Technologie sind drahtlose Bluetooth-Headsets zu einem unverzichtbaren Bestandteil des täglichen Lebens der Menschen geworden. Das Aufkommen kabelloser Kopfhörer macht unsere Hände frei und ermöglicht es uns, Musik, Anrufe und andere Unterhaltungsaktivitäten freier zu genießen. Wenn wir fliegen, werden wir jedoch oft gebeten, unsere Telefone in den Flugmodus zu versetzen. Die Frage ist also: Kann ich Bluetooth-Kopfhörer im Flugzeugmodus verwenden? In diesem Artikel gehen wir dieser Frage nach. Lassen Sie uns zunächst verstehen, was der Flugzeugmodus bewirkt und bedeutet. Der Flugmodus ist ein spezieller Modus für Mobiltelefone

Detaillierte Erläuterung von Win11-Kompatibilitätsproblemen mit Win10-Software Detaillierte Erläuterung von Win11-Kompatibilitätsproblemen mit Win10-Software Jan 05, 2024 am 11:18 AM

Die Software im Win10-System wurde perfekt optimiert, aber für die neuesten Win11-Benutzer muss jeder neugierig sein, ob dieses System unterstützt werden kann. Im Folgenden finden Sie eine detaillierte Einführung in Win11-Software, die Win10 nicht unterstützt. Kommen Sie und finden Sie es heraus zusammen. Unterstützt Win11 Win10-Software: 1. Win10-Systemsoftware und sogar Win7-Systemanwendungen sind gut kompatibel. 2. Laut Feedback von Experten, die das Win11-System verwenden, gibt es derzeit keine Probleme mit der Anwendungsinkompatibilität. 3. Sie können also bedenkenlos ein Upgrade durchführen. Normalen Benutzern wird jedoch empfohlen, mit dem Upgrade zu warten, bis die offizielle Version von Win11 veröffentlicht wird. 4. Win11 ist nicht nur gut kompatibel, sondern verfügt auch über Windo

WIN10-Kompatibilität verloren, Schritte zur Wiederherstellung WIN10-Kompatibilität verloren, Schritte zur Wiederherstellung Mar 27, 2024 am 11:36 AM

1. Klicken Sie mit der rechten Maustaste auf das Programm und stellen Sie fest, dass die Registerkarte [Kompatibilität] im sich öffnenden Eigenschaftenfenster nicht zu finden ist. 2. Klicken Sie auf dem Win10-Desktop mit der rechten Maustaste auf die Schaltfläche „Start“ in der unteren linken Ecke des Desktops und wählen Sie im Popup-Menü den Menüpunkt [Ausführen]. 3. Das Win10-Ausführungsfenster wird geöffnet. Geben Sie gpedit.msc in das Fenster ein und klicken Sie dann auf die Schaltfläche OK. 4. Das Fenster „Lokaler Gruppenrichtlinien-Editor“ wird geöffnet. Klicken Sie im Fenster auf den Menüpunkt [Computerkonfiguration/Administrative Vorlagen/Windows-Komponenten]. 5. Suchen Sie im geöffneten Windows-Komponentenmenü den Menüpunkt [Anwendungskompatibilität] und dann im rechten Fenster den Einstellungspunkt [Eigenschaftsseite für Programmkompatibilität entfernen]. 6. Klicken Sie mit der rechten Maustaste auf das Einstellungselement und im Popup-Menü

Die Beziehung zwischen js und vue Die Beziehung zwischen js und vue Mar 11, 2024 pm 05:21 PM

Die Beziehung zwischen js und vue: 1. JS als Eckpfeiler der Webentwicklung; 2. Der Aufstieg von Vue.js als Front-End-Framework; 3. Die komplementäre Beziehung zwischen JS und Vue; Vue.

See all articles