事件处理如何在JavaScript内部进行工作?

前端之家收集整理的这篇文章主要介绍了事件处理如何在JavaScript内部进行工作?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
具体 Spidermonkey.

我知道你写函数并附加到事件来处理它们.

在何处定义了onClick处理程序,JS引擎知道如何在用户点击时触发onClick事件?

任何关键字,设计模式,链接等都不胜感激.

UPDATE

聚合链接我在这里发现有用

http://www.w3.org/TR/DOM-Level-2-Events/events.html

https://github.com/joyent/node/blob/master/src/node_events.cc

http://mxr.mozilla.org/mozilla/source/dom/src/events/nsJSEventListener.cpp

解决方法

SpiderMonkey本身没有涉及事件处理的任何东西.事件纯粹是DOM的事情.

点击事件由浏览器代码(嵌入SpiderMonkey的东西)触发,而不是SpiderMonkey本身.请参阅http://hg.mozilla.org/mozilla-central/file/e60b8be7a97b/content/events/src/nsEventStateManager.cpp中的代码,负责调度诸如点击之类的代码.

浏览器还定义了setter方法,它们将赋值给onclick属性并将其转换为事件侦听器注册.请参阅从nsEventReceiverSH :: SetProperty调用http://hg.mozilla.org/mozilla-central/file/e60b8be7a97b/dom/base/nsDOMClassInfo.cpp#l7624,并处理其名称(此代码中的id)通过IsEventName测试的属性.

当事件侦听器被注册并且事件被触发时,事件分派器管理对侦听器的呼叫;您发现的nsJSEventListener链接是将C HandleEvent调用转换为对JS函数调用的粘合.

所以在你的情况下,你想要某种注册/注销机制的监听器,然后你的实现将触发事件并将它们发送到监听器.这最后一部分是如何开放的? Gecko实现由于需要实现DOM Events规范而受到很多限制,但您应该能够做得更简单一些.

原文链接:https://www.f2er.com/js/154798.html

猜你在找的JavaScript相关文章