Heim > Web-Frontend > js-Tutorial > Hauptteil

Browserübergreifende Ereignisse in JavaScript (grafisches Tutorial)

亚连
Freigeben: 2018-05-21 13:43:28
Original
1087 Leute haben es durchsucht

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;
  }
};
Nach dem Login kopieren

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;
  }
};
Nach dem Login kopieren

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);
    }
  }
Nach dem Login kopieren

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);
  }
}
Nach dem Login kopieren

Standardverhalten bei browserübergreifender Blockierung

function preDef(ev){
    var e = ev || window.event;
    if(e.preventDefault){
      e.preventDefault();
    }else{
      e.returnValue =false;
    }
  }
Nach dem Login kopieren

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;
  }
}
Nach dem Login kopieren

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;
    }
  }
Nach dem Login kopieren

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
        }
      }
    },
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage