博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[javascript] 看知乎学习js事件触发过程
阅读量:5875 次
发布时间:2019-06-19

本文共 1604 字,大约阅读时间需要 5 分钟。

 

红色箭头代表捕获阶段

蓝色代表目标阶段

绿色代表冒泡阶段

 

调用元素对象的addEventListener()方法,参数:事件,回调函数,是否捕获(true代表捕获阶段,false代表冒泡阶段,ie浏览器不支持在捕获阶段绑定事件因此一般写false)

 

在回调函数中,传递进来Event事件对象

获取Event对象的target属性,代表当前的元素对象

 

使用事件代理,给父节点绑定监听事件,可以提升性能,可以减少绑定给每个子节点

停止事件冒泡,调用Event对象的stopPropagation()方法,降低事件的复杂性

知乎:javascript的事件处理阶段问题?

 

在DOM 2中,事件流有三个阶段,事件捕获阶段,处于目标阶段和事件冒泡阶段。

var btn=document.getElementById("myBtn");

btn.οnclick=function(){

         alert("Clicked");

}

以这种方式添加的事件处理程序会在事件流的冒泡阶段被处理。

var btn=document.getElementById("myBtn");

btn.addEventListener("click",function(){

         alert(this.id);

},false);

以这种方法添加的事件处理程序如果左后一个参数是true,表示在捕获阶段调用事件处理程序,如果是false,表示在冒泡阶段调用事件处理程序。

var btn=document.getElementById("myBtn");

btn.attachEvent("onclick",function(){

         alert("Clicked");

});

 

以这种方法添加的事件处理程序都会被添加到冒泡阶段。

---------------------------------------------------------------------------------------------------------------

 

然后event对象都有一个属性eventPhase,表示调用事件处理程序的阶段,属性的值可以为1,2,3,

1. 表示捕获阶段

2. 表示“处于目标”

3. 表示冒泡阶段

问题一:当调用这个属性的时候输出的结果都是2,什么时候会出现其他的结果?

问题二:根据上面的3个例子事件处理程序的在哪个阶段被处理,那么eventPhase不就是它在哪个阶段被处理的结果?

问题三:不同阶段处理事件,会有什么不同?有具体的例子吗?

 

李力:

问题一:

document.body.addEventListener("click", function(event){

         alert(event.eventPhase);  // 1  捕获阶段,document.body 上的事件处理程序

}, true);

 

myBtn.onclick = function(event){

         alert(event.eventPhase);  // 2  目标上的事件处理程序

}

 

document.body.onclick = function(event){

         alert(event.eventPhase);  // 3  冒泡阶段,document.body 上的事件处理程序

}

事件流说的是页面接收事件的顺序,而所谓的”冒泡“、”捕获“是相对于目标元素而言的。

 

问题二:

“尽管处于目标发生在冒泡阶段,但evenPhase仍然一直等于2”。——《JavaScript高级程序设计》。

我在看这部分的时候,觉得挺合理的。既然是目标元素的事件处理程序,当然得在处于目标阶段处理事件了啊。

具体为什么我也在找答案,求大神讲解。

 

转载于:https://www.cnblogs.com/taoshihan/p/5438729.html

你可能感兴趣的文章
python mysql Connect Pool mysql连接池 (201
查看>>
Boost在vs2010下的配置
查看>>
android camera(四):camera 驱动 GT2005
查看>>
一起谈.NET技术,ASP.NET伪静态的实现及伪静态的意义
查看>>
20款绝佳的HTML5应用程序示例
查看>>
string::c_str()、string::c_data()及string与char *的正确转换
查看>>
11G数据的hive初测试
查看>>
如何使用Core Text计算一段文本绘制在屏幕上之后的高度
查看>>
==和equals区别
查看>>
2010技术应用计划
查看>>
XML 节点类型
查看>>
驯服 Tiger: 并发集合 超越 Map、Collection、List 和 Set
查看>>
Winform开发框架之权限管理系统改进的经验总结(3)-系统登录黑白名单的实现...
查看>>
Template Method Design Pattern in Java
查看>>
MVC输出字符串常用四个方式
查看>>
LeetCode – LRU Cache (Java)
查看>>
JavaScript高级程序设计--对象,数组(栈方法,队列方法,重排序方法,迭代方法)...
查看>>
【转】 学习ios(必看经典)牛人40天精通iOS开发的学习方法【2015.12.2
查看>>
nginx+php的使用
查看>>
在 ASP.NET MVC 中使用异步控制器
查看>>