From 5d49335eace4311de890b871e057d8b6e9122eb6 Mon Sep 17 00:00:00 2001 From: jeresig Date: Wed, 13 Jan 2010 00:12:18 -0500 Subject: [PATCH] Make sure that disconnected nodes aren't sorted/uniqued. Fixes #5791. --- src/traversing.js | 12 +++++++++--- test/unit/core.js | 13 +++++++++---- 2 files changed, 18 insertions(+), 7 deletions(-) diff --git a/src/traversing.js b/src/traversing.js index a09ae19..d0dd52d 100644 --- a/src/traversing.js +++ b/src/traversing.js @@ -146,9 +146,9 @@ jQuery.fn.extend({ jQuery.makeArray( selector ), all = jQuery.merge( this.get(), set ); - return this.pushStack( set[0] && (set[0].setInterval || set[0].nodeType === 9 || (set[0].parentNode && set[0].parentNode.nodeType !== 11)) ? - jQuery.unique( all ) : - all ); + return this.pushStack( isDisconnected( set[0] ) || isDisconnected( all[0] ) ? + all : + jQuery.unique( all ) ); }, andSelf: function() { @@ -156,6 +156,12 @@ jQuery.fn.extend({ } }); +// A painfully simple check to see if an element is disconnected +// from a document (should be improved, where feasible). +function isDisconnected( node ) { + return !node || !node.parentNode || node.parentNode.nodeType === 11; +} + jQuery.each({ parent: function( elem ) { var parent = elem.parentNode; diff --git a/test/unit/core.js b/test/unit/core.js index 85b421d..0026929 100644 --- a/test/unit/core.js +++ b/test/unit/core.js @@ -501,6 +501,15 @@ test("add(String|Element|Array|undefined)", function() { // use jQuery([]).add(form.elements) instead. //equals( jQuery([]).add(jQuery("#form")[0].elements).length, jQuery(jQuery("#form")[0].elements).length, "Array in constructor must equals array in add()" ); + var divs = jQuery("
").add("#sndp"); + ok( !divs[0].parentNode, "Make sure the first element is still the disconnected node." ); + + divs = jQuery("
test
").add("#sndp"); + equals( divs[0].parentNode.nodeType, 11, "Make sure the first element is still the disconnected node." ); + + divs = jQuery("#sndp").add("
"); + ok( !divs[1].parentNode, "Make sure the first element is still the disconnected node." ); + var tmp = jQuery("
"); var x = jQuery([]).add(jQuery("

xxx

").appendTo(tmp)).add(jQuery("

xxx

").appendTo(tmp)); @@ -522,10 +531,6 @@ test("add(String|Element|Array|undefined)", function() { var notDefined; equals( jQuery([]).add(notDefined).length, 0, "Check that undefined adds nothing" ); - // Added after #2811 - equals( jQuery([]).add([window,document,document.body,document]).length, 3, "Pass an array" ); - equals( jQuery(document).add(document).length, 1, "Check duplicated elements" ); - equals( jQuery(window).add(window).length, 1, "Check duplicated elements using the window" ); ok( jQuery([]).add( document.getElementById('form') ).length >= 13, "Add a form (adds the elements)" ); }); -- 1.7.10.4