博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浏览器的事件机制
阅读量:6656 次
发布时间:2019-06-25

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

Propagation At this point, we should ask an important question—if an element and one of its ancestors have a handler on the same event, which handler will be fired first? Consider the following figure: For example, we have Element2 as a child of Element1 and both have the onClick handler. When a user clicks on Element2, onClick on both Element2 and Element1 is triggered but the question is which one is triggered first. What should the event order be? Well, the answer, unfortunately, is that it depends entirely on the browser. When browsers first arrived, two opinions emerged, naturally, from Netscape and Microsoft. Netscape decided that the first event triggered should be Element1's onClick. This event ordering is known as event capturing. Microsoft decided that the first event triggered should be Element2's onClick. This event ordering is known as event bubbling. Chapter 8 [ 195 ] These are two completely opposite views and implementations of how browsers handled events. To end this madness, World Wide Web Consortium (W3C) decided a wise middle path. In this model, an event is first captured until it reaches the target element and then bubbles up again. In this standard behavior, you can choose in which phase you want to register your event handler—either in the capturing or bubbling phase. If the last argument is true in addEventListener(), the event handler is set for the capturing phase, if it is false, the event handler is set for the bubbling phase. There are times when you don't want the event to be raised by the parents if it was already raised by the child. You can call the stopPropagation() method on the event object to prevent handlers further up from receiving the event. Several events have a default action associated with them. For example, if you click on a URL link, you will be taken to the link's target. The JavaScript event handlers are called before the default behavior is performed. You can call the preventDefault() method on the event object to stop the default behavior from being triggered. These are event basics when you are using plain JavaScript on a browser. There is a problem here. Browsers are notorious when it comes to defining event-handling behavior. We will look at jQuery's event handling. To make things easier to manage, jQuery always registers event handlers for the bubbling phase of the model. This means that the most specific elements will get the first opportunity to respond to any event.

转载地址:http://vfxto.baihongyu.com/

你可能感兴趣的文章
LNMP环境下nginx、php-fpm的配置文件讲解
查看>>
会声会影截取视频教程
查看>>
Mysql多库连接
查看>>
PHP中getenv函数
查看>>
菜鸟学Linux 第112篇笔记 虚拟化xen
查看>>
Outlook2013 设置 @me.com 、 @icloud.com
查看>>
Ubunt搭建PHP+mysql+apache
查看>>
从入门到精通AD中的5种操作主机
查看>>
windows 2003的三种安装方法
查看>>
rsync的搭建
查看>>
海量数据:判断一棵树是否为另一棵树的子树
查看>>
OpenGL 世界坐标系
查看>>
30家首尔甜品店大推荐!
查看>>
位运算的妙用_判断2的乘方和二进制1的个数
查看>>
sqlplus链接成功,PL/SQL报错:“ORA-12154: TNS:无法解析指定的连接标识符"
查看>>
JS-----------阻止事件的冒泡传播
查看>>
linux目录结构详细介绍
查看>>
Subversion svn无法添加新文件问题
查看>>
SVM入门(六)线性分类器的求解——问题的转化,直观角度
查看>>
#pragma once与 #ifndef的区别
查看>>