JS li onclick funktioniert nicht unter IE8
Problem:
Im bereitgestellten Code ist das li-Element Das Klickereignis wird im Internet Explorer nicht ausgelöst 8.
Lösung:
IE8 unterstützt addEventListener nicht. Verwenden Sie stattdessen seinen nicht standardmäßigen Vorgänger, attachmentEvent.
Codeänderung:
Erstellen Sie zunächst eine Funktion zur Verarbeitung der Ereignisverknüpfung:
var hookEvent = (function() { var div; function standardHookEvent(element, eventName, handler) { element.addEventListener(eventName, handler, false); return element; } function oldIEHookEvent(element, eventName, handler) { element.attachEvent("on" + eventName, function(e) { e = e || window.event; e.preventDefault = oldIEPreventDefault; e.stopPropagation = oldIEStopPropagation; handler.call(element, e); }); return element; } function oldIEPreventDefault() { this.returnValue = false; } function oldIEStopPropagation() { this.cancelBubble = true; } div = document.createElement('div'); if (div.addEventListener) { div = undefined; return standardHookEvent; } if (div.attachEvent) { div = undefined; return oldIEHookEvent; } throw "Neither modern event mechanism (addEventListener nor attachEvent) is supported by this browser."; })();
Verwenden Sie als Nächstes diese Funktion, um das Ereignis einzubinden Listener:
hookEvent(document.getElementById("hd_vertical"), "click", function(e) { // Your event handling code here });
Hinweis:
IE8 bietet auch keine Unterstützung für getElementsByClassName. Verwenden Sie stattdessen querySelectorAll oder querySelector:
var _url = document.querySelectorAll("." + id)[1].getAttribute('href');
Das obige ist der detaillierte Inhalt vonWarum funktioniert mein JS „li' onclick im IE8 nicht?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!