// Handle triggering a single element
} else if ( element["on" + type] ) {
- // Pass along a fake event
- data.unshift( this.fix({ type: type, target: element }) );
-
- // Trigger the event
- element["on" + type].apply( element, data );
+ if ( element[ type ] && element[ type ].constructor == Function )
+ element[ type ]();
+ else {
+ // Pass along a fake event
+ data.unshift( this.fix({ type: type, target: element }) );
+
+ // Trigger the event
+ element["on" + type].apply( element, data );
+ }
}
},
handle: function(event) {
if ( typeof jQuery == "undefined" ) return false;
- event = jQuery.event.fix( event || window.event || {} ); // Empty object is for triggered events with no data
+ // Empty object is for triggered events with no data
+ event = jQuery.event.fix( event || window.event || {} );
// returned undefined or false
var returnValue;
}
// check if target is a textnode (safari)
- if (event.target.nodeType == 3) {
- // store a copy of the original event object and clone because target is read only
+ if (jQuery.browser.safari && event.target.nodeType == 3) {
+ // store a copy of the original event object
+ // and clone because target is read only
var originalEvent = event;
event = jQuery.extend({}, originalEvent);
// get parentnode from textnode
event.target = originalEvent.target.parentNode;
- // add preventDefault and stopPropagation since they will not work on the clone
+ // add preventDefault and stopPropagation since
+ // they will not work on the clone
event.preventDefault = function() {
return originalEvent.preventDefault();
};
}
// fix preventDefault and stopPropagation
- if (!event.preventDefault) {
+ if (!event.preventDefault)
event.preventDefault = function() {
this.returnValue = false;
};
- }
- if (!event.stopPropagation) {
+ if (!event.stopPropagation)
event.stopPropagation = function() {
this.cancelBubble = true;
};
- }
return event;
}
/**
* The opposite of bind, removes a bound event from each of the matched
- * elements. You must pass the identical function that was used in the original
- * bind method.
+ * elements.
*
- * @example $("p").unbind( "click", function() { alert("Hello"); } )
+ * Without any arguments, all bound events are removed.
+ *
+ * If the type is provided, all bound events of that type are removed.
+ *
+ * If the function that was passed to bind is provided as the second argument,
+ * only that specific event handler is removed.
+ *
+ * @example $("p").unbind()
* @before <p onclick="alert('Hello');">Hello</p>
* @result [ <p>Hello</p> ]
*
- * @name unbind
- * @type jQuery
- * @param String type An event type
- * @param Function fn A function to unbind from the event on each of the set of matched elements
- * @cat Events
- */
-
- /**
- * Removes all bound events of a particular type from each of the matched
- * elements.
- *
* @example $("p").unbind( "click" )
* @before <p onclick="alert('Hello');">Hello</p>
* @result [ <p>Hello</p> ]
*
- * @name unbind
- * @type jQuery
- * @param String type An event type
- * @cat Events
- */
-
- /**
- * Removes all bound events from each of the matched elements.
- *
- * @example $("p").unbind()
+ * @example $("p").unbind( "click", function() { alert("Hello"); } )
* @before <p onclick="alert('Hello');">Hello</p>
* @result [ <p>Hello</p> ]
*
* @name unbind
* @type jQuery
+ * @param String type (optional) An event type
+ * @param Function fn (optional) A function to unbind from the event on each of the set of matched elements
* @cat Events
*/
unbind: function( type, fn ) {
* @name scroll
* @type jQuery
* @param Function fn A function to bind to the scroll event on each of the matched elements.
- * @cat Events/Browser
- */
-
- /**
- * Trigger the scroll event of each matched element. This causes all of the functions
- * that have been bound to thet scroll event to be executed.
- *
- * @example $("p").scroll();
- * @before <p onscroll="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name scroll
- * @type jQuery
- * @cat Events/Browser
+ * @cat Events
*/
/**
* @name submit
* @type jQuery
* @param Function fn A function to bind to the submit event on each of the matched elements.
- * @cat Events/Form
+ * @cat Events
*/
/**
*
* @name submit
* @type jQuery
- * @cat Events/Form
+ * @cat Events
*/
/**
* @name focus
* @type jQuery
* @param Function fn A function to bind to the focus event on each of the matched elements.
- * @cat Events/UI
+ * @cat Events
*/
/**
*
* @name focus
* @type jQuery
- * @cat Events/UI
+ * @cat Events
*/
/**
* @name keydown
* @type jQuery
* @param Function fn A function to bind to the keydown event on each of the matched elements.
- * @cat Events/Keyboard
- */
-
- /**
- * Trigger the keydown event of each matched element. This causes all of the functions
- * that have been bound to thet keydown event to be executed.
- *
- * @example $("p").keydown();
- * @before <p onkeydown="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name keydown
- * @type jQuery
- * @cat Events/Keyboard
+ * @cat Events
*/
/**
* @name dblclick
* @type jQuery
* @param Function fn A function to bind to the dblclick event on each of the matched elements.
- * @cat Events/Mouse
- */
-
- /**
- * Trigger the dblclick event of each matched element. This causes all of the functions
- * that have been bound to thet dblclick event to be executed.
- *
- * @example $("p").dblclick();
- * @before <p ondblclick="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name dblclick
- * @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
/**
* @name keypress
* @type jQuery
* @param Function fn A function to bind to the keypress event on each of the matched elements.
- * @cat Events/Keyboard
- */
-
- /**
- * Trigger the keypress event of each matched element. This causes all of the functions
- * that have been bound to thet keypress event to be executed.
- *
- * @example $("p").keypress();
- * @before <p onkeypress="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name keypress
- * @type jQuery
- * @cat Events/Keyboard
+ * @cat Events
*/
/**
* @name error
* @type jQuery
* @param Function fn A function to bind to the error event on each of the matched elements.
- * @cat Events/Browser
- */
-
- /**
- * Trigger the error event of each matched element. This causes all of the functions
- * that have been bound to thet error event to be executed.
- *
- * @example $("p").error();
- * @before <p onerror="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name error
- * @type jQuery
- * @cat Events/Browser
+ * @cat Events
*/
/**
* @name blur
* @type jQuery
* @param Function fn A function to bind to the blur event on each of the matched elements.
- * @cat Events/UI
+ * @cat Events
*/
/**
*
* @name blur
* @type jQuery
- * @cat Events/UI
+ * @cat Events
*/
/**
* @name load
* @type jQuery
* @param Function fn A function to bind to the load event on each of the matched elements.
- * @cat Events/Browser
- */
-
- /**
- * Trigger the load event of each matched element. This causes all of the functions
- * that have been bound to thet load event to be executed.
- *
- * Marked as private: Calling load() without arguments throws exception because the ajax load
- * does not handle it.
- *
- * @example $("p").load();
- * @before <p onload="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name load
- * @private
- * @type jQuery
- * @cat Events/Browser
+ * @cat Events
*/
/**
* @name select
* @type jQuery
* @param Function fn A function to bind to the select event on each of the matched elements.
- * @cat Events/Form
+ * @cat Events
*/
/**
*
* @name select
* @type jQuery
- * @cat Events/Form
+ * @cat Events
*/
/**
* @name mouseup
* @type jQuery
* @param Function fn A function to bind to the mouseup event on each of the matched elements.
- * @cat Events/Mouse
- */
-
- /**
- * Trigger the mouseup event of each matched element. This causes all of the functions
- * that have been bound to thet mouseup event to be executed.
- *
- * @example $("p").mouseup();
- * @before <p onmouseup="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name mouseup
- * @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
/**
* @name unload
* @type jQuery
* @param Function fn A function to bind to the unload event on each of the matched elements.
- * @cat Events/Browser
- */
-
- /**
- * Trigger the unload event of each matched element. This causes all of the functions
- * that have been bound to thet unload event to be executed.
- *
- * @example $("p").unload();
- * @before <p onunload="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name unload
- * @type jQuery
- * @cat Events/Browser
+ * @cat Events
*/
/**
* @name change
* @type jQuery
* @param Function fn A function to bind to the change event on each of the matched elements.
- * @cat Events/Form
- */
-
- /**
- * Trigger the change event of each matched element. This causes all of the functions
- * that have been bound to thet change event to be executed.
- *
- * @example $("p").change();
- * @before <p onchange="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name change
- * @type jQuery
- * @cat Events/Form
+ * @cat Events
*/
/**
* @name mouseout
* @type jQuery
* @param Function fn A function to bind to the mouseout event on each of the matched elements.
- * @cat Events/Mouse
- */
-
- /**
- * Trigger the mouseout event of each matched element. This causes all of the functions
- * that have been bound to thet mouseout event to be executed.
- *
- * @example $("p").mouseout();
- * @before <p onmouseout="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name mouseout
- * @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
/**
* @name keyup
* @type jQuery
* @param Function fn A function to bind to the keyup event on each of the matched elements.
- * @cat Events/Keyboard
- */
-
- /**
- * Trigger the keyup event of each matched element. This causes all of the functions
- * that have been bound to thet keyup event to be executed.
- *
- * @example $("p").keyup();
- * @before <p onkeyup="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name keyup
- * @type jQuery
- * @cat Events/Keyboard
+ * @cat Events
*/
/**
* @name click
* @type jQuery
* @param Function fn A function to bind to the click event on each of the matched elements.
- * @cat Events/Mouse
+ * @cat Events
*/
/**
*
* @name click
* @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
/**
* @name resize
* @type jQuery
* @param Function fn A function to bind to the resize event on each of the matched elements.
- * @cat Events/Browser
- */
-
- /**
- * Trigger the resize event of each matched element. This causes all of the functions
- * that have been bound to thet resize event to be executed.
- *
- * @example $("p").resize();
- * @before <p onresize="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name resize
- * @type jQuery
- * @cat Events/Browser
+ * @cat Events
*/
/**
* @name mousemove
* @type jQuery
* @param Function fn A function to bind to the mousemove event on each of the matched elements.
- * @cat Events/Mouse
- */
-
- /**
- * Trigger the mousemove event of each matched element. This causes all of the functions
- * that have been bound to thet mousemove event to be executed.
- *
- * @example $("p").mousemove();
- * @before <p onmousemove="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name mousemove
- * @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
/**
* @name mousedown
* @type jQuery
* @param Function fn A function to bind to the mousedown event on each of the matched elements.
- * @cat Events/Mouse
- */
-
- /**
- * Trigger the mousedown event of each matched element. This causes all of the functions
- * that have been bound to thet mousedown event to be executed.
- *
- * @example $("p").mousedown();
- * @before <p onmousedown="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name mousedown
- * @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
/**
* @name mouseover
* @type jQuery
* @param Function fn A function to bind to the mousedown event on each of the matched elements.
- * @cat Events/Mouse
- */
-
- /**
- * Trigger the mouseover event of each matched element. This causes all of the functions
- * that have been bound to thet mousedown event to be executed.
- *
- * @example $("p").mouseover();
- * @before <p onmouseover="alert('Hello');">Hello</p>
- * @result alert('Hello');
- *
- * @name mouseover
- * @type jQuery
- * @cat Events/Mouse
+ * @cat Events
*/
-
- var e = ("blur,focus,load,resize,scroll,unload,click,dblclick," +
+ jQuery.each( ("blur,focus,load,resize,scroll,unload,click,dblclick," +
"mousedown,mouseup,mousemove,mouseover,mouseout,change,select," +
- "submit,keydown,keypress,keyup,error").split(",");
-
- // Go through all the event names, but make sure that
- // it is enclosed properly
- for ( var i = 0; i < e.length; i++ ) new function(){
-
- var o = e[i];
+ "submit,keydown,keypress,keyup,error").split(","), function(i,o){
// Handle event binding
jQuery.fn[o] = function(f){
return f ? this.bind(o, f) : this.trigger(o);
};
-
- // Handle event unbinding
- // TODO remove
- jQuery.fn["un"+o] = function(f){ return this.unbind(o, f); };
-
- // Finally, handle events that only fire once
- // TODO remove
- jQuery.fn["one"+o] = function(f){
- // save cloned reference to this
- var element = jQuery(this);
- var handler = function() {
- // unbind itself when executed
- element.unbind(o, handler);
- element = null;
- // apply original handler with the same arguments
- return f.apply(this, arguments);
- };
- return this.bind(o, handler);
- };
- };
+ });
// If Mozilla is used
- if ( jQuery.browser.mozilla || jQuery.browser.opera ) {
+ if ( jQuery.browser.mozilla || jQuery.browser.opera )
// Use the handy event callback
document.addEventListener( "DOMContentLoaded", jQuery.ready, false );
// If IE is used, use the excellent hack by Matthias Miller
// http://www.outofhanwell.com/blog/index.php?title=the_window_onload_problem_revisited
- } else if ( jQuery.browser.msie ) {
+ else if ( jQuery.browser.msie ) {
// Only works if you document.write() it
document.write("<scr" + "ipt id=__ie_init defer=true " +
// Use the defer script hack
var script = document.getElementById("__ie_init");
- if (script) // script does not exist if jQuery is loaded dynamically
+
+ // script does not exist if jQuery is loaded dynamically
+ if ( script )
script.onreadystatechange = function() {
if ( this.readyState != "complete" ) return;
this.parentNode.removeChild( this );
script = null;
// If Safari is used
- } else if ( jQuery.browser.safari ) {
+ } else if ( jQuery.browser.safari )
// Continually check to see if the document.readyState is valid
jQuery.safariTimer = setInterval(function(){
// loaded and complete are both valid states
// and execute any waiting functions
jQuery.ready();
}
- }, 10);
- }
+ }, 10);
// A fallback to window.onload, that will always work
jQuery.event.add( window, "load", jQuery.ready );
};
// Clean up after IE to avoid memory leaks
-if (jQuery.browser.msie) jQuery(window).unload(function() {
- var event = jQuery.event, global = event.global;
- for (var type in global) {
- var els = global[type], i = els.length;
- if (i>0) do if (type != 'unload') event.remove(els[i-1], type); while (--i);
- }
-});
+if (jQuery.browser.msie)
+ jQuery(window).one("unload", function() {
+ var global = jQuery.event.global;
+ for ( var type in global ) {
+ var els = global[type], i = els.length;
+ if ( i && type != 'unload' )
+ do
+ jQuery.event.remove(els[i-1], type);
+ while (--i);
+ }
+ });
\ No newline at end of file