事件和方法有什么区别

事件是特殊的方法,基本一样,两个名词而言,事件这个名词只是更好的表述了自已的特性。

事件更多强调是一种改变,一般是持久化关键数据的改变如状态变迁。方法可能只是计算中间结果。
事件更多强调或固化了的事件发起者与事件的响应者的数据关联,强调双方的互动。方法可能在调用者与被调用者(执行者)间并没有数据参数。
事件更多强调或固化了一种一对多的互动关系。而方法更多的是一对一的关系。

事件更多的关注了事件发起者,发起事件的原因及发起方式。如时间事件,更改状态事件,信号事件,简单的调用事件。
揭秘UML状态机视图中的四大事件
http://developer.51cto.com/art/201006/206489.htm
————————————————
版权声明:本文为优快云博主「cxzhq2002」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/cxzhq2002/article/details/6231725

事件冒泡事件捕获是HTML DOM中处理事件事件传播的两种不同方式,它们的区别主要体现在以下几个方面: - **传播方向**:事件冒泡是从触发它的最内层元素(目标元素)开始,然后逐级向上传播到外层元素,直到达到DOM树的根节点;而事件捕获则相反,是从DOM树的根节点开始,然后逐级向下传播到目标元素[^2]。 - **事件处理程序执行顺序**:在事件冒泡阶段,子元素的事件处理程序会先于父元素的事件处理程序执行;在事件捕获阶段,父元素的事件处理程序会先于子元素的事件处理程序执行[^2]。 - **默认行为**:默认情况下,大多数事件处理程序在事件冒泡阶段触发。可以通过`addEventListener`方法的第三个参数来指定事件是在事件捕获阶段还是事件冒泡阶段处理。当该参数为`true`时,表示在捕获阶段处理事件;为`false`或省略时,表示在冒泡阶段处理事件[^2]。 - **应用场景**:事件冒泡适用于事件委托统一管理与处理事件,可减少事件处理程序的数量,提高性能代码的可维护性;事件捕获适用于前置操作或细粒度控制,以及阻止事件冒泡,可在事件到达目标元素之前进行验证或修改事件的行为[^2]。 以下是一个简单的示例代码,展示事件冒泡事件捕获的区别: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> </head> <body> <div id="outer"> Outer Div <div id="inner"> Inner Div </div> </div> <script> const outerDiv = document.getElementById('outer'); const innerDiv = document.getElementById('inner'); // 事件捕获 outerDiv.addEventListener('click', function () { console.log('Outer Div - Capturing'); }, true); innerDiv.addEventListener('click', function () { console.log('Inner Div - Capturing'); }, true); // 事件冒泡 outerDiv.addEventListener('click', function () { console.log('Outer Div - Bubbling'); }, false); innerDiv.addEventListener('click', function () { console.log('Inner Div - Bubbling'); }, false); </script> </body> </html> ``` 当点击`innerDiv`时,控制台会先输出捕获阶段的信息(从外到内),再输出冒泡阶段的信息(从内到外)。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值