zoukankan      html  css  js  c++  java
  • JavaScript经典实例(浏览器事件)

    跨浏览器事件

    1.跨浏览器添加事件

    function addEvent(obj,type,fn){
      if(obj.addEventListener){
        obj.addEventListener(type,fn,false);
      }else if(obj.attachEvent){//IE
        obj.attchEvent('on'+type,fn);
      }
    }

    2.跨浏览器移除事件

    function removeEvent(obj,type,fn){
        if(obj.removeEventListener){
            obj.removeEventListener(type,fn,false);
        }else if(obj.detachEvent){//兼容IE
            obj.detachEvent('on'+type,fn);
        }
    }

    3.跨浏览器阻止默认行为

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

    4.跨浏览器获取目标对象

    function getTarget(ev){
        if(ev.target){//w3c
            return ev.target;
        }else if(window.event.srcElement){//IE
            return window.event.srcElement;
        }
    }

    5.跨浏览器获取滚动条位置

    function getSP(){
        return{
            top: document.documentElement.scrollTop || document.body.scrollTop,
            left : document.documentElement.scrollLeft || document.body.scrollLeft;
        }
    }

    6.跨浏览器获取可视窗口大小

    function  getWindow () {
        if(typeof window.innerWidth !='undefined') {
            return{
                width : window.innerWidth,
                height : window.innerHeight
            }
        } else{
            return {
                width : document.documentElement.clientWidth,
                height : document.documentElement.clientHeight
            }
        }
    },
  • 相关阅读:
    Scala教程之:静态类型
    java运行时跟编译时的区别,欢迎大家指正
    循环者的诅咒
    Python分支结构与流程控制
    底层剖析Python深浅拷贝
    I/O格式化与运算符
    详解Python垃圾回收机制
    LeetCode29 Medium 不用除号实现快速除法
    详解SkipList跳跃链表【含代码】
    高等数学——讲透微分中值定理
  • 原文地址:https://www.cnblogs.com/ssjd/p/12956533.html
Copyright © 2011-2022 走看看