事件模型

DOM事件流(不适用于IE8及以下版本IE)

“DOM2级事件”规定的事件流包括三个阶段
当一个事件发生以后,它会在不同的DOM节点之间传播(propagation)。这种传播分成三个阶段:

第一阶段:从window对象传导到目标节点,称为“捕获阶段”(capture phase)。
第二阶段:在目标节点上触发,称为“目标阶段”(target phase)。
第三阶段:从目标节点传导回window对象,称为“冒泡阶段”(bubbling phase)。

绑定监听函数的方法

  1. HTML元素的on-属性
//js中定义fun方法。
    <script type="text/javascript">
        function fun(){
            console.log(this)
        }
    </script>
<div id="test" onclick="fun()"></div>
//等同于 使用元素节点的setAttribute方法 设置相应的属性。
document.getElementById("test").setAttribute('onclick', 'fun()')
//等效于
document.getElementById("test").onclick=function onclick(event) {
    fun()
}
  • 属性值是可执行的代码,而不是监听函数,所以要执行函数,不要忘记加上一对圆括号。
  • 事件触发后" "中的代码被执行。定义好的fun函数被调用。函数调用模式,非严格模式fun函数中this指向window。
  • 使用这个方法指定的监听函数,只会在冒泡阶段触发。
  • 若要访问event对象。必须要这样。在调用监听函数时间,一定要显示传入event对象

<div id="test" onclick="fun(event)"></div>

  1. Element节点的事件属性
    Element节点有事件属性,同样可以指定监听函数。
div.onclick = function(){ console.log(this)};
  • 事件触发后执行该元素节点的onclick方法。方法调用模式 , 函数中this指向该节点对象。
  • 使用这个方法指定的监听函数,只会在冒泡阶段触发。
  • 只能给元素节点和document节点指定监听函数,不能给文本节点指定监听函数。
  1. 使用addEventListener方法也可以在,定义一个特定事件的监听函数。
    addEventListener是推荐的指定监听函数的方法。它有如下优点:

可以针对同一个事件,添加多个监听函数。
能够指定在哪个阶段(捕获阶段还是冒泡阶段)触发监听函数,默认为false(只在冒泡阶段被触发)。
除了DOM节点(所有DOM节点),还可以部署在window、XMLHttpRequest等对象上面,等于统一了整个JavaScript的监听函数接口。

  • addEventListener 添加的方法只能用remoEventListener 移除
事件绑定时的this指向

以下写法的this对都指向Element节点:

// JavaScript代码
element.onclick = printelement.addEventListener('click', print, false)
element.onclick = function () {console.log(this.id);}
// HTML代码
<element onclick="console.log(this.id)">

以下写法的this,都指向全局对象。

// JavaScript代码
element.onclick = function (){ doSomething() };
element.setAttribute('onclick', 'doSomething()');
// HTML代码
<element onclick="doSomething()">

在监听函数中,currentTarget属性实际上等同于this对象。

IE8及以下版本,事件对象不作为参数传递,而是通过window对象的event属性读取,并且事件对象的target属性叫做srcElement属性。所以,以前获取事件信息,往往要写成下面这样。

     var actualEvent = event || window.event;
     var actualTarget = actualEvent.target || actualEvent.srcElement;
     //...
}```
  其他浏览器中事件对象会作为参传递,同时会将值赋给window.event
#####preventDefault():
preventDefault方法取消浏览器对当前事件的默认行为,比如点击链接 后,浏览器跳转到指定页面,或者按一下空格键,页面向下滚动一段距离。该方法生效的前提是,事件的cancelable属性为true,如果为false,则调用该方法没有任何效果。
#####event.stopPropagation():
stopPropagation方法阻止事件在DOM中继续传播,防止再触发定义在别的节点上的监听函数,但是不包括在当前节点上新定义的事件监听函数。

function stopEvent(e) {
e.stopPropagation();
}
el.addEventListener('click', stopEvent, false);


将上面函数指定为监听函数,会阻止事件进一步冒泡到el节点的父节点。
#####event.cancelBubble=true;
event.cancelBubble=true 阻止事件冒泡。不同于event.stopPropagation() 它阻止的只是冒泡阶段的事件传递,
关于阻止事件传递,一直有如下谬论:
>event.cancelBubble=true用于ie的阻止冒泡事件,
event.stopPropagation()用于firefox和chrome等其他浏览器。

ie9及以上版本IE,和其他浏览器(chrome Firefox safari opera Edge)中都可以用event.cancelBubble=true;取消事件冒泡。除此之外,这些浏览量器相对于低版本IE 还有了event.stopPropagation()方法 用于阻止事件在DOM中继续传播包括捕获和冒泡。

#####event.stopImmediatePropagation()
stopImmediatePropagation
方法阻止同一个事件的其他监听函数被调用。
如果同一个节点对于同一个事件指定了多个监听函数,这些函数会根据添加的顺序依次调用。只要其中有一个监听函数调用了stopImmediatePropagation方法,其他的监听函数就不会再执行了。

function l1(e){
e.stopImmediatePropagation();
}
function l2(e){
console.log('hello world');
}el.addEventListener('click', l1, false);
el.addEventListener('click', l2, false);

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

推荐阅读更多精彩内容