From: Yehuda Katz Date: Tue, 21 Jul 2009 09:17:33 +0000 (+0000) Subject: Adds detach() X-Git-Url: http://git.asbjorn.biz/?p=jquery.git;a=commitdiff_plain;h=7a67f8897d3c2ed97254f0fdb969be14e77962d1 Adds detach() --- diff --git a/src/manipulation.js b/src/manipulation.js index 583d445..1b8066f 100644 --- a/src/manipulation.js +++ b/src/manipulation.js @@ -37,7 +37,7 @@ jQuery.fn.extend({ jQuery(this).wrapAll( html.apply(this, arguments) ); }); } - + if ( this[0] ) { // The elements to wrap the target around var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone(); @@ -183,7 +183,7 @@ jQuery.fn.extend({ cached = true; } } - + if ( !fragment ) { fragment = (this[0].ownerDocument || this[0]).createDocumentFragment(); scripts = jQuery.clean( args, (this[0].ownerDocument || this[0]), fragment ); @@ -249,18 +249,21 @@ jQuery.each({ }); jQuery.each({ - remove: function( selector ) { + // keepData is for internal use only--do not document + remove: function( selector, keepData ) { if ( !selector || jQuery.multiFilter( selector, [ this ] ).length ) { - if ( this.nodeType === 1 ) { + if ( !keepData && this.nodeType === 1 ) { cleanData( jQuery("*", this).add(this) ); } - if ( this.parentNode ) { - this.parentNode.removeChild( this ); - } + this.parentNode && this.parentNode.removeChild( this ); } }, + detach: function( selector ) { + jQuery( this ).remove( selector, true ) + }, + empty: function() { // Remove element nodes and prevent memory leaks if ( this.nodeType === 1 ) { diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js index 88e7d71..8a61ba6 100644 --- a/test/unit/manipulation.js +++ b/test/unit/manipulation.js @@ -65,7 +65,7 @@ var testWrapAll = function(val) { expect(8); var prev = jQuery("#firstp")[0].previousSibling; var p = jQuery("#firstp,#first")[0].parentNode; - + var result = jQuery('#firstp,#first').wrapAll(val( '
' )); equals( result.parent().length, 1, 'Check for wrapping of on-the-fly html' ); ok( jQuery('#first').parent().parent().is('.red'), 'Check if wrapper has class "red"' ); @@ -79,7 +79,7 @@ var testWrapAll = function(val) { var result = jQuery('#firstp,#first').wrapAll(val( document.getElementById('empty') )); equals( jQuery("#first").parent()[0], jQuery("#firstp").parent()[0], "Same Parent" ); equals( jQuery("#first").parent()[0].previousSibling, prev, "Correct Previous Sibling" ); - equals( jQuery("#first").parent()[0].parentNode, p, "Correct Parent" ); + equals( jQuery("#first").parent()[0].parentNode, p, "Correct Parent" ); } test("wrapAll(String|Element)", function() { @@ -104,7 +104,7 @@ var testWrapInner = function(val) { var result = jQuery('#first').wrapInner(document.getElementById('empty')); equals( jQuery("#first").children().length, 1, "Only one child" ); ok( jQuery("#first").children().is("#empty"), "Verify Right Element" ); - equals( jQuery("#first").children().children().length, num, "Verify Elements Intact" ); + equals( jQuery("#first").children().children().length, num, "Verify Elements Intact" ); } test("wrapInner(String|Element)", function() { @@ -250,7 +250,7 @@ test("appendTo(String|Element|Array<Element>|jQuery)", function() { var div = jQuery("
").appendTo("#main, #moretests"); equals( div.length, 2, "appendTo returns the inserted elements" ); - + div.addClass("test"); ok( jQuery("#main div:last").hasClass("test"), "appendTo element was modified after the insertion" ); @@ -390,7 +390,7 @@ var testAfter = function(val) { reset(); expected = "This is a normal link: YahoodiveintomarkTry them out:"; jQuery('#yahoo').after(val( jQuery("#first, #mark") )); - equals( expected, jQuery('#en').text(), "Insert jQuery after" ); + equals( expected, jQuery('#en').text(), "Insert jQuery after" ); }; test("after(String|Element|Array<Element>|jQuery)", function() { @@ -444,7 +444,7 @@ var testReplaceWith = function(val) { jQuery('#yahoo').replaceWith(val( jQuery("#first, #mark") )); ok( jQuery("#first")[0], 'Replace element with set of elements' ); ok( jQuery("#mark")[0], 'Replace element with set of elements' ); - ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after set of elements' ); + ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after set of elements' ); } test("replaceWith(String|Element|Array<Element>|jQuery)", function() { @@ -460,7 +460,7 @@ test("replaceAll(String|Element|Array<Element>|jQuery)", function() { jQuery('buga').replaceAll("#yahoo"); ok( jQuery("#replace")[0], 'Replace element with string' ); ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after string' ); - + reset(); jQuery(document.getElementById('first')).replaceAll("#yahoo"); ok( jQuery("#first")[0], 'Replace element with element' ); @@ -549,24 +549,24 @@ test("val()", function() { document.getElementById('text1').value = "bla"; equals( jQuery("#text1").val(), "bla", "Check for modified value of input element" ); - + reset(); equals( jQuery("#text1").val(), "Test", "Check for value of input element" ); // ticket #1714 this caused a JS error in IE equals( jQuery("#first").val(), "", "Check a paragraph element to see if it has a value" ); ok( jQuery([]).val() === undefined, "Check an empty jQuery object will return undefined from val" ); - + equals( jQuery('#select2').val(), '3', 'Call val() on a single="single" select' ); isSet( jQuery('#select3').val(), ['1', '2'], 'Call val() on a multiple="multiple" select' ); equals( jQuery('#option3c').val(), '2', 'Call val() on a option element with value' ); - + equals( jQuery('#option3a').val(), '', 'Call val() on a option element with empty value' ); - + equals( jQuery('#option3e').val(), 'no value', 'Call val() on a option element with no value attribute' ); - + }); var testVal = function(valueObj) { @@ -574,7 +574,7 @@ var testVal = function(valueObj) { jQuery("#text1").val(valueObj( 'test' )); equals( document.getElementById('text1').value, "test", "Check for modified (via val(String)) value of input element" ); - + jQuery("#text1").val(valueObj( 67 )); equals( document.getElementById('text1').value, "67", "Check for modified (via val(Number)) value of input element" ); @@ -601,11 +601,11 @@ test("val(Function)", function() { var testHtml = function(valueObj) { expect(17); - + window.debug = true; - + jQuery.scriptorder = 0; - + var div = jQuery("#main > div"); div.html(valueObj("test")); var pass = true; @@ -613,39 +613,39 @@ var testHtml = function(valueObj) { if ( div.get(i).childNodes.length != 1 ) pass = false; } ok( pass, "Set HTML" ); - + window.debug = false; reset(); // using contents will get comments regular, text, and comment nodes var j = jQuery("#nonnodes").contents(); j.html(valueObj("bold")); - + // this is needed, or the expando added by jQuery unique will yield a different html j.find('b').removeData(); equals( j.html().replace(/ xmlns="[^"]+"/g, "").toLowerCase(), "bold", "Check node,textnode,comment with html()" ); - + jQuery("#main").html(valueObj("