Zuallererst ist es erwähnenswert, dass es Browserkompatibilitätsprobleme mit Methoden oder Objekten wie der Ereignisverarbeitung und der Verhinderung der Weitergabe von Ereignissen gibt. Während des Entwicklungsprozesses ist es am besten, eine universelle Ereignisverarbeitung zu schreiben Nun, als nächstes werfen wir einen Blick auf die grundlegenden Methoden von browserübergreifenden Ereignisoperationen in JavaScript
Binden von Ereignissen
EU.addHandler = function(element,type,handler){ //DOM2级事件处理,IE9也支持 if(element.addEventListener){ element.addEventListener(type,handler,false); } else if(element.attachEvent){ //type加'on' //IE9也可以这样绑定 element.attachEvent('on' + type,handler); } //DOM0级事件处理步,事件流也是冒泡 else{ element['on' + type] = handler; } };
Entbinden von Ereignissen und Bindung Die Verarbeitung bestimmter Ereignisse ist grundsätzlich gleich, mit einem Hinweis:
Der übergebene Handler muss derselbe sein wie der Handler, der beim Binden des Ereignisses übergeben wurde (auf dieselbe Funktion zeigen)
EU.removeHandler = function(element,type,handler){ if(element.removeEventListener){ element.removeEventListener(type,handler); } else if(element.attachEvent){ element.detachEvent('on' + type,handler); } else{ //属性置空就可以 element['on' + type] = null; } };
Browserübergreifende Ereignisse werden hinzugefügt
function addEvent(obj,type,fn){ if(obj.addEventListener){ obj.addEventListener(type,fn,false); }else if(obj.attachEvent){//IE obj.attchEvent('on'+type,fn); } }
Browserübergreifendes Entfernungsereignis
function removeEvent(obj,type,fn){ if(obj.removeEventListener){ obj.removeEventListener(type,fn,false); }else if(obj.detachEvent){//兼容IE obj.detachEvent('on'+type,fn); } }
Standardverhalten bei browserübergreifender Blockierung
function preDef(ev){ var e = ev || window.event; if(e.preventDefault){ e.preventDefault(); }else{ e.returnValue =false; } }
Das Zielobjekt in allen Browsern abrufen
function getTarget(ev){ if(ev.target){//w3c return ev.target; }else if(window.event.srcElement){//IE return window.event.srcElement; } }
Die Position der Bildlaufleiste in allen Browsern abrufen
//跨浏览器获取滚动条位置,sp == scroll position function getSP(){ return{ top: document.documentElement.scrollTop || document.body.scrollTop, left : document.documentElement.scrollLeft || document.body.scrollLeft; } }
Das Bildmaterial abrufen Fenstergröße in verschiedenen Browsern
function getWindow () { if(typeof window.innerWidth !='undefined') { return{ width : window.innerWidth, height : window.innerHeight } } else{ return { width : document.documentElement.clientWidth, height : document.documentElement.clientHeight } } },
Ich habe das Obige für Sie zusammengestellt und hoffe, dass es Ihnen in Zukunft hilfreich sein wird.
Verwandte Artikel:
Detaillierte Analyse und Antworten auf das Prinzip der JavaScript-Operation
Über Eclipse zum Entfernen von js (JavaScript ) Überprüfungsfehler (Details Antwort)
Grundlegende JavaScript-Tipps (Bild- und Text-Tutorials, detaillierte Antworten für Sie)
Das obige ist der detaillierte Inhalt vonBrowserübergreifende Ereignisse in JavaScript (grafisches Tutorial). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!