JS事件中的兼容问题

1. 事件对象event的兼容问题

    IE9+ :  event                      IE9- : window.event

e = e || window.event;
可简写为:
e = e || event;

2. 获取鼠标位置 pageX, pageY 的兼容问题

    e.clientX / e.clientY     无兼容问题 (获取到页面可视框的距离)   

    e.pageX / e.pageY    IE9+ (9-不兼容)

function getXY(e){
            e = e || window.event;
            var x = 0,
                y = 0;
            if(e.pageX){
                x = e.pageX;
                y = e.pageY;
            }else{
                var cleft = document.documentElement.scrollLeft;
                var ctop = document.documentElement.scrollTop;
                x = cleft + e.clientX;
                y = ctop + e.clientY;
            }
            return {x:x,y:y};
        }

3. 添加事件的兼容问题

    element.addEventListener(type, function, boolean);

    elemnet.attachEvent(type, function, boolean);    IE

function bind(el, type, callBack){
            if(el.addEventListener){
                el.addEventListener(type, callBack);
            }else{
                el.attachEvent("on"+type, callBack);
            }
        }

4. 事件对象获取目标事件对象的兼容问题

    event有两个属性:

                1. 获取当前事件对象(e.currentTarget)

                2. 获取目标事件对象(e.target / e.srcElement)

var target = e.target || e.srcElement;

当前事件对象就是添加了监听事件的对象,而目标事件对象可能不一样,举例说明吧

<div id="box"><span>点我</span></div>

给div注册点击事件,当前对象就是div,鼠标点div时目标事件是div,而鼠标点span标签时,目标事件是span,点谁谁是目标事件对象,其他的事件也一样.

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值