jQuery源码探索之路(6)-- 事件绑定的不同

  1. 自己最近在学习一些JS插件的写法,那么当然就绕不开jquery,于是自己就边学习边模仿,写一个自己的jQuery
  1. 自己也是在学习过程中,有问题请各位指出,希望大伙能多多支持,多点star
    源码github地址
jQuery源码探索之路

.addEventListener(type , fn , false)

这是除了IE都支持的绑定事件的API,这里不讲兼容问题,主要是要看JQ内部是如何绑定事件的,后续还会写JQ是如何实现事件代理的。
addEventListener具体解释可以上MDN或W3C看,这里直接看怎么使用。

首先,addEventListener是可以重复绑定的,而不会覆盖,比如

绑定两个
click后触发

但是在JQ中,如果是要绑定多个function到同一个DOM上,就不是重复调用addEventListener了,而是使用一个数组去将这些fn缓存,然后绑定一个主监听,在这个主监听fn中,将数组里的fn一个个的倒出来调用。

上个代码的例子你就明白了

var b2 = document.getElementById("box2");
var events = [];
for(var i = 0; i < 300; i++){
    events.push(function(){
        console.log("数组缓存fn");
    })
}
b2.addEventListener('click',function(e){
    var target = e.target;
    for(var i = 0; i < events.length; i++){
        events[i].call(target,e);
    }
})

当在DOM上触发事件后,会去执行绑定的方法,在这个主监听fn中有个for循环,将events数组中缓存的fn一个个的调用。

使用call方法改变具体fn里的this指向的上下文。
将e作为参数传递给每个fn。

明白了这个,JQ的事件模块就能看懂了。

两种方法的比较

我一直认为后面这种方法只是是代码看起来简单优雅,没有那么多的重复内容,不明白性能上会不会有什么差异。
为了探索性能的差异,我写了一段代码粗糙的测试一下

//执行绑定的开始时间戳和结束时间戳
    var start,end;
    //触发事件,执行的开始时间戳和结束时间戳
    var addStart,addEnd;

    var b1 = document.getElementById('box1');
    var b2 = document.getElementById("box2");
    
    addStart = new Date().getTime();
    b1.addEventListener('click',function(e){
        start = new Date();
        console.log("开始执行");
    },false)
    for(var i = 0; i < 3000; i++){
        b1.addEventListener('click',function(e){
            console.log("重复addEventListener绑定");
        });
    }
    b1.addEventListener('click',function(e){
        console.log("结束执行")
        end = new Date();
        console.log("第一种方法执行时间",end.getTime() - start.getTime());
    })
    addEnd = new Date().getTime();
    console.log('使用重复addEventListener绑定消耗事件:',addEnd - addStart);



    addStart = new Date().getTime();
    var events = [];
    for(var i = 0; i < 3000; i++){
        events.push(function(){
            console.log("使用数组缓存fn");
        })
    }
    b2.addEventListener('click',function(e){
        var target = e.target;
        start = new Date();
        for(var i = 0; i < events.length; i++){
            events[i].call(target,e);
        }
        end = new Date();
        console.log("使用数组执行时间",end.getTime() - start.getTime());
    })
    addEnd = new Date().getTime();
    console.log("使用数组缓存消耗时间:",addEnd - addStart);

代码里都有注释,应该看得懂,直接上测试结果

测试结果

可以看到在执行绑定的时候,重复的使用addEventListener消耗的事件比使用数组push要慢得多。
而在触发click事件执行函数的时候,两者的时间相差不大。

我找不到浏览器内部处理addEventListener API相关的解释,猜测它应该也是已数组的形式储存同一个DOM的同一类型事件,所以两者的时间才会差不多。

希望有知道具体解释的朋友告诉我。

明白了两者的不同,后面简易的写JQ的事件绑定方式就简单啦,敬请期待吧!


附:

既然您看都看完了,麻烦您点个赞,给个star呗,谢谢您的支持!!!
源码地址:https://github.com/LY550275752/my-js-plug/blob/master/Ye.js

如果您不知道我在说什么的话,推荐您从头开始看我的这个系列文章:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容

  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,332评论 0 2
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,169评论 0 1
  • (续jQuery基础(1)) 第5章 DOM节点的复制与替换 (1)DOM拷贝clone() 克隆节点是DOM的常...
    凛0_0阅读 1,332评论 0 8
  • 昨天听了逯薇老师的收纳课。 逯薇老师把收纳与她的建筑学背景联系起来,整理出一套简单易懂的收纳方法。现在我把听课笔记...
    小萌妮阅读 2,190评论 0 5
  • “如果每天早下班一个小时,人生进程会不会提前一个小时?”伍佰问西贝。 “你吃撑的没事做吧,你想得都是啥啊?”西贝嫌...
    人一一阅读 134评论 0 0