yishuixs 2015-09-09 12:57 采纳率: 100%
浏览 1539
已采纳

用自定义的传统事件绑定函数代替attachEvent的一些问题

我看了一个教程,上面写了一个用自定义的传统事件绑定函数来代替IE8及以上的老IE的attachEvent方法,主讲老师写了一点看不懂,哪位能解释一下,代码如下:
HTML代码:

<body>
    <input type="button" value="按钮" id="button" />
</body>

JS代码:

addEvent(obj, type, fn){
    //先创建一个保存事件的容器obj.events对象
    if(!obj.events) obj.events = {};

    //再创建一个保存事件处理函数的容器obj.events[type]数组
    if(!obj.events[type]){
        var obj.events[type] = [];
        if(obj['on'+type]) obj.events[type][0] = fn;  //这里就不同了,先写出主讲老师的方法
    }
    //第二次执行时保存
    obj.events[type][addEvent.ID++] = fn;

    //开始执行
    obj['on'+type] = function(){
        for(var i in obj.events[type]){
            obj.events[type][i]();
        }
    }
}

//事件计数器
addEvent.ID = 1;

//开始执行
addEvent(window, 'load', function(){
    var button = document.getElementById('button');
    addEvent(button, 'click', fn1);
    addEvent(button, 'click', fn2);
    addEvent(button, 'click', fn3);
});

function fn1(){
    alert(1);
}

function fn2(){
    alert(2);
}

function fn3(){
    alert(3);
}

主讲老师在用obj.events[type][0]保存fn时,前面加了一个判断,即if(obj['on'+type]),这个判断的结果是点击了按钮后,分别弹出1、2、3,而不加这个判断,则为1、1、2、3四次。

我自己没有用这个办法,而是加了一个else分支,也能实现弹出1、2、3三次

if(!obj.events[type]){
    var obj.events[type] = [];
    obj.events[type][0] = fn;
} else {
    obj.events[type][addEvent.ID++] = fn;
}

我想问的是,主讲老师讲的办法即加了一个if(obj['on'+type])的判断是如何起作用的?为何加了之后也能将原来多出来的一次1弹窗去掉呢?

  • 写回答

1条回答 默认 最新

  • devmiao 2015-09-09 15:17
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog