diff options
author | Dave Methvin <dave.methvin@gmail.com> | 2011-04-12 19:29:09 -0400 |
---|---|---|
committer | Dave Methvin <dave.methvin@gmail.com> | 2011-04-12 19:29:09 -0400 |
commit | bebd8bc01e63dcb053412f8b247e4fa611867c55 (patch) | |
tree | 1908fde77bb03270e6d703bb67a35021d0969c58 /src/event.js | |
parent | 6d49e84dafd8990221913944727e4f5dcaec078d (diff) | |
download | jquery-bebd8bc01e63dcb053412f8b247e4fa611867c55.tar.gz jquery-bebd8bc01e63dcb053412f8b247e4fa611867c55.zip |
Followup to #8753. Modify new Event constructor signature to jQuery.event(type, props), which can be exploited by jQuery.event.trigger as well.
Diffstat (limited to 'src/event.js')
-rw-r--r-- | src/event.js | 24 |
1 files changed, 9 insertions, 15 deletions
diff --git a/src/event.js b/src/event.js index f005f7285..dd48e7f77 100644 --- a/src/event.js +++ b/src/event.js @@ -304,9 +304,9 @@ jQuery.event = { // jQuery.Event object event[ jQuery.expando ] ? event : // Object literal - jQuery.extend( new jQuery.Event(type), event ) : + new jQuery.Event( type, event ) : // Just the event type (string) - new jQuery.Event(type); + new jQuery.Event( type ); event.type = type; event.namespace = namespaces.join("."); @@ -563,26 +563,15 @@ jQuery.removeEvent = document.removeEventListener ? } }; -jQuery.Event = function( src ) { +jQuery.Event = function( src, props ) { // Allow instantiation without the 'new' keyword if ( !this.preventDefault ) { - return new jQuery.Event( src ); + return new jQuery.Event( src, props ); } // Event object if ( src && src.type ) { this.originalEvent = src; - - // Push explicitly provided properties onto the event object - for ( var prop in src ) { - // Ensure we don't clobber jQuery.Event prototype - // with own properties. - if ( hasOwn.call( src, prop ) ) { - this[ prop ] = src[ prop ]; - } - } - - // Always ensure a type has been explicitly set this.type = src.type; // Events bubbling up the document may have been marked as prevented @@ -595,6 +584,11 @@ jQuery.Event = function( src ) { this.type = src; } + // Put explicitly provided properties onto the event object + if ( props ) { + jQuery.extend( this, props ); + } + // timeStamp is buggy for some events on Firefox(#3843) // So we won't rely on the native value this.timeStamp = jQuery.now(); |