Heim  >  Artikel  >  Web-Frontend  >  Browserübergreifende Ereignisse in JavaScript (grafisches Tutorial)

Browserübergreifende Ereignisse in JavaScript (grafisches Tutorial)

亚连
亚连Original
2018-05-21 13:43:281074Durchsuche

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!

Stellungnahme:
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