[英]When should I observe Javascript events on window vs. document vs. document.body?
我正在将prototype.js用于我的网络应用程序,并且我已经在Chrome,Safari和Firefox上运行了所有内容。 我现在正致力于IE8的兼容性。
正如我在IE中调试的那样,我注意到有一些Javascript事件,我以前在窗口上设置了一个观察者,例如
Event.observe(window, eventType, function () {...});
(其中eventType
可能是"dom:loaded"
, "keypress"
等),它在Chrome / Safari / Firefox中运行良好。 然而,在IE中,观察者永远不会发射。
至少在某些情况下,我可以通过将观察者放在window
以外的其他东西上来使用它来工作,例如document
(在"dom:loaded"
的情况下)或document.body
(在"keypress"
的情况下) 。 但是,这都是反复试验。
是否有更系统的方法来确定这些观察者的位置,以便结果将跨浏览器兼容?
(这不是一个非常全面的答案,但它似乎在经验上有效 - 所以希望这些经验法则对其他人有帮助。)
通常,在document
上注册事件,而不是window
。 Webkit和Mozilla浏览器似乎都很满意,但是IE不响应窗口上注册的大多数事件,所以你需要使用document
来处理IE
例外: resize
,并且应该在窗口上设置与加载,卸载和打开/关闭相关的事件。
第一个异常的例外: dom:loaded
必须在IE中的document
上设置。
另一个例外:当在启用了find-as-you-type的情况下检测Mozilla下的击键时,在window
而不是document
上设置关键事件观察者。 如果你使用后者,find-as-you-type似乎会阻止事件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.