aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Ramos <paul.b.ramos@gmail.com>2012-12-10 16:12:54 -0500
committerDave Methvin <dave.methvin@gmail.com>2012-12-11 23:35:22 -0500
commitf12611feb43adb2b014eb2183db0713451746aff (patch)
treef860ba7ae1a785f024c0a4fb670e7f8be5c127bb
parentaad235b3251494afe71fd5bb6031e11965af9bdb (diff)
downloadjquery-f12611feb43adb2b014eb2183db0713451746aff.tar.gz
jquery-f12611feb43adb2b014eb2183db0713451746aff.zip
Fix #4087. insertAfter, insertBefore, etc do not work if origin and destination are same element. Close gh-1068.
-rw-r--r--src/manipulation.js12
-rw-r--r--test/unit/manipulation.js34
2 files changed, 42 insertions, 4 deletions
diff --git a/src/manipulation.js b/src/manipulation.js
index ffaa5c4c4..b9d5f0ff1 100644
--- a/src/manipulation.js
+++ b/src/manipulation.js
@@ -254,7 +254,7 @@ jQuery.fn.extend({
// Make sure that the elements are removed from the DOM before they are inserted
// this can help fix replacing a parent with child elements
if ( !isFunc && typeof value !== "string" ) {
- value = jQuery( value ).detach();
+ value = jQuery( value ).not( this ).detach();
}
return this.domManip( [ value ], true, function( elem ) {
@@ -303,7 +303,7 @@ jQuery.fn.extend({
if ( this[0] ) {
doc = this[0].ownerDocument;
fragment = doc.createDocumentFragment();
- jQuery.clean( args, doc, fragment );
+ jQuery.clean( args, doc, fragment, undefined, this );
first = fragment.firstChild;
if ( fragment.childNodes.length === 1 ) {
@@ -619,7 +619,7 @@ jQuery.extend({
return clone;
},
- clean: function( elems, context, fragment, scripts ) {
+ clean: function( elems, context, fragment, scripts, selection ) {
var elem, j, tmp, tag, wrap, tbody,
ret = [],
i = 0,
@@ -714,7 +714,11 @@ jQuery.extend({
safe = jQuery.contains( elem.ownerDocument, elem );
// Append to fragment
- fragment.appendChild( elem );
+ // #4087 - If origin and destination elements are the same, and this is
+ // that element, do not append to fragment
+ if ( !( selection && jQuery.inArray( elem, selection ) !== -1 ) ) {
+ fragment.appendChild( elem );
+ }
tmp = getAll( elem, "script" );
// Preserve script evaluation history
diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js
index 9d8c93321..41db7291d 100644
--- a/test/unit/manipulation.js
+++ b/test/unit/manipulation.js
@@ -2274,3 +2274,37 @@ test( "wrapping scripts (#10470)", function() {
strictEqual( script.parentNode, jQuery("#qunit-fixture > b")[ 0 ], "correctly wrapped" );
jQuery( script ).remove();
});
+
+test( "insertAfter, insertBefore, etc do not work when destination is original element. Element is removed (#4087)", function() {
+
+ expect( 10 );
+
+ var elems;
+
+ jQuery.each([
+ "appendTo",
+ "prependTo",
+ "insertBefore",
+ "insertAfter",
+ "replaceAll"
+ ], function( index, name ) {
+ elems = jQuery( [
+ "<ul id='test4087-complex'><li class='test4087'><div>c1</div>h1</li><li><div>c2</div>h2</li></ul>",
+ "<div id='test4087-simple'><div class='test4087-1'>1<div class='test4087-2'>2</div><div class='test4087-3'>3</div></div></div>",
+ "<div id='test4087-multiple'><div class='test4087-multiple'>1</div><div class='test4087-multiple'>2</div></div>"
+ ] ).appendTo( "#qunit-fixture" );
+
+ // complex case based on http://jsfiddle.net/pbramos/gZ7vB/
+ jQuery("#test4087-complex div")[ name ]("#test4087-complex li:last-child div:last-child");
+ equal( jQuery("#test4087-complex li:last-child div").length, name === "replaceAll" ? 1 : 2, name +" a node to itself, complex case." );
+
+ // simple case
+ jQuery( ".test4087-1" )[ name ](".test4087-1");
+ equal( jQuery(".test4087-1").length, 1, name +" a node to itself, simple case." );
+
+ // clean for next test
+ jQuery("#test4087-complex").remove();
+ jQuery("#test4087-simple").remove();
+ jQuery("#test4087-multiple").remove();
+ });
+});