diff options
author | Jordan Boesch <jboesch26@gmail.com> | 2011-03-05 09:46:12 -0600 |
---|---|---|
committer | Jordan Boesch <jboesch26@gmail.com> | 2011-03-05 09:46:12 -0600 |
commit | c9ef09c800ba7b6510d9e3a68f053ae29409f621 (patch) | |
tree | b58bf511662c0b0dff3a61e499661b5c6f43fae2 | |
parent | 5c2d70979c15bbda5c90e1634abe11d8c350abcb (diff) | |
download | jquery-c9ef09c800ba7b6510d9e3a68f053ae29409f621.tar.gz jquery-c9ef09c800ba7b6510d9e3a68f053ae29409f621.zip |
bug 6158; fixing replaceWith from throwing errors on non existant elements
-rw-r--r-- | src/manipulation.js | 7 | ||||
-rw-r--r-- | test/unit/manipulation.js | 7 |
2 files changed, 8 insertions, 6 deletions
diff --git a/src/manipulation.js b/src/manipulation.js index a4a81de44..613faabb9 100644 --- a/src/manipulation.js +++ b/src/manipulation.js @@ -261,10 +261,9 @@ jQuery.fn.extend({ } }); } else { - if ( !this.length ) { - return this; - } - return this.pushStack( jQuery(jQuery.isFunction(value) ? value() : value), "replaceWith", value ); + return ( this.length ) ? + this.pushStack( jQuery(jQuery.isFunction(value) ? value() : value), "replaceWith", value ) : + this; } }, diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js index 34425ed3a..1169032ce 100644 --- a/test/unit/manipulation.js +++ b/test/unit/manipulation.js @@ -739,7 +739,7 @@ test("insertAfter(String|Element|Array<Element>|jQuery)", function() { }); var testReplaceWith = function(val) { - expect(20); + expect(21); jQuery('#yahoo').replaceWith(val( '<b id="replace">buga</b>' )); ok( jQuery("#replace")[0], 'Replace element with string' ); ok( !jQuery("#yahoo")[0], 'Verify that original element is gone, after string' ); @@ -799,6 +799,9 @@ var testReplaceWith = function(val) { var set = jQuery("<div/>").replaceWith(val("<span>test</span>")); equals( set[0].nodeName.toLowerCase(), "span", "Replace the disconnected node." ); equals( set.length, 1, "Replace the disconnected node." ); + + var non_existant = jQuery('#does-not-exist').replaceWith( val("<b>should not throw an error</b>") ); + equals( non_existant.length, 0, "Length of non existant element." ) var $div = jQuery("<div class='replacewith'></div>").appendTo("body"); // TODO: Work on jQuery(...) inline script execution @@ -827,7 +830,7 @@ test("replaceWith(String|Element|Array<Element>|jQuery)", function() { test("replaceWith(Function)", function() { testReplaceWith(functionReturningObj); - expect(21); + expect(22); var y = jQuery("#yahoo")[0]; |