From 4424bda377336342ce04ab5299bf1ce624cdb7b1 Mon Sep 17 00:00:00 2001 From: Dave Methvin Date: Mon, 20 Dec 2010 22:23:59 -0500 Subject: [PATCH 1/2] Use a for loop rather than for/in loop when copying events, so that code will work with an augmented Array.prototype. Fixes 7809. --- src/manipulation.js | 10 +++++----- test/unit/manipulation.js | 3 +++ 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/src/manipulation.js b/src/manipulation.js index 7dea3493c..9d70a7b03 100644 --- a/src/manipulation.js +++ b/src/manipulation.js @@ -370,14 +370,14 @@ function root( elem, cur ) { } function cloneCopyEvent(orig, ret) { - var i = 0; + var node = 0; ret.each(function() { - if ( this.nodeType !== 1 || this.nodeName !== (orig[i] && orig[i].nodeName) ) { + if ( this.nodeType !== 1 || this.nodeName !== (orig[node] && orig[node].nodeName) ) { return; } - var oldData = jQuery.data( orig[i++] ), + var oldData = jQuery.data( orig[node++] ), curData = jQuery.data( this, oldData ), events = oldData && oldData.events; @@ -386,8 +386,8 @@ function cloneCopyEvent(orig, ret) { curData.events = {}; for ( var type in events ) { - for ( var handler in events[ type ] ) { - jQuery.event.add( this, type, events[ type ][ handler ], events[ type ][ handler ].data ); + for ( var i = 0, l = events[ type ].length; i < l; i++ ) { + jQuery.event.add( this, type, events[ type ][ i ], events[ type ][ i ].data ); } } } diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js index d49029eb8..cbc0b7715 100644 --- a/test/unit/manipulation.js +++ b/test/unit/manipulation.js @@ -1,5 +1,8 @@ module("manipulation"); +// Ensure that an extended Array prototype doesn't break jQuery +Array.prototype.arrayProtoFn = function(arg) { throw("arrayProtoFn should not be called"); }; + var bareObj = function(value) { return value; }; var functionReturningObj = function(value) { return (function() { return value; }); }; From acab4ab0e50fadacb106468b1449643b9a03826b Mon Sep 17 00:00:00 2001 From: Dave Methvin Date: Tue, 21 Dec 2010 10:00:49 -0500 Subject: [PATCH 2/2] Use for loop instead of for/in loop to protect sanctity of Array.prototype. Fixes #7817. Test case for this commit is shared with the fix for #6355, https://github.com/jquery/jquery/pull/140 . --- src/xhr.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/xhr.js b/src/xhr.js index 57903e046..4896e6cb6 100644 --- a/src/xhr.js +++ b/src/xhr.js @@ -87,7 +87,7 @@ jQuery.xhr = function( _native ) { } // Apply option prefilters - for (i in prefilters) { + for ( i = 0; i < prefilters.length; i++ ) { prefilters[i](s); }