// And bind the global event handler to the element
if (element.addEventListener)
element.addEventListener(type, element.$handle, false);
- else if (element.attachEvent)
+ else
element.attachEvent("on" + type, element.$handle);
}
if ( !ret ) {
if (element.removeEventListener)
element.removeEventListener(type, element.$handle, false);
- else if (element.detachEvent)
+ else
element.detachEvent("on" + type, element.$handle);
ret = null;
delete events[type];
// Calculate pageX/Y if missing and clientX/Y available
if ( event.pageX == null && event.clientX != null ) {
- var e = document.documentElement || document.body;
- event.pageX = event.clientX + e.scrollLeft;
- event.pageY = event.clientY + e.scrollTop;
+ var e = document.documentElement, b = document.body;
+ event.pageX = event.clientX + (e && e.scrollLeft || b.scrollLeft || 0);
+ event.pageY = event.clientY + (e && e.scrollTop || b.scrollTop || 0);
}
// Add which for key events
f.apply( document, [jQuery] );
// Otherwise, remember the function for later
- else {
+ else
// Add the function to the wait list
jQuery.readyList.push( function() { return f.apply(this, [jQuery]) } );
- }
return this;
}
// script does not exist if jQuery is loaded dynamically
if ( script )
script.onreadystatechange = function() {
- if ( this.readyState != "complete" ) return;
+ if ( document.readyState != "complete" ) return;
jQuery.ready();
};