From 8c91da57b9fbc8ded9854a899e4105530cea1d90 Mon Sep 17 00:00:00 2001 From: Dave Methvin Date: Thu, 8 Sep 2011 15:59:23 -0400 Subject: [PATCH] Fix #9593. Create a new jQuery.Event rather than a plain object when simulate()ing events. Fix a related issue with not passing src to jQuery.Event constructor. --- src/event.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/event.js b/src/event.js index 4b50f93a2..688aa9fb0 100644 --- a/src/event.js +++ b/src/event.js @@ -644,7 +644,7 @@ jQuery.Event = function( src, props ) { } // Create a timestamp if incoming event doesn't have one - this.timeStamp = src.timeStamp || jQuery.now(); + this.timeStamp = src && src.timeStamp || jQuery.now(); // Mark it as fixed this[ jQuery.expando ] = true; @@ -875,7 +875,7 @@ function simulate( type, elem, event, bubble ) { // Piggyback on a donor event to simulate a different one. // Fake originalEvent to avoid donor's stopPropagation, but if the // simulated event prevents default then we do the same on the donor. - var e = jQuery.extend( {}, event, { type: type, originalEvent: {} } ); + var e = jQuery.extend( new jQuery.Event(), event, { type: type, originalEvent: {} } ); if ( bubble ) { jQuery.event.trigger( e, null, elem ); } else {