diff options
author | Oleg <markelog@gmail.com> | 2011-11-13 12:10:21 +0400 |
---|---|---|
committer | Dave Methvin <dave.methvin@gmail.com> | 2011-11-14 11:30:53 -0500 |
commit | a467aa0a779b8741581cc2ab1fcd914f5718f5c8 (patch) | |
tree | 9d08e1d02b4e1c2af138c5b23d4b3e624e0a75ab | |
parent | fa96f4bdeedd5b134ea1923e1147b4282fa4d6fa (diff) | |
download | jquery-a467aa0a779b8741581cc2ab1fcd914f5718f5c8.tar.gz jquery-a467aa0a779b8741581cc2ab1fcd914f5718f5c8.zip |
Fix #10773. Improve parameter handling in removeAttr.
-rw-r--r-- | src/attributes.js | 6 | ||||
-rw-r--r-- | test/unit/attributes.js | 57 |
2 files changed, 38 insertions, 25 deletions
diff --git a/src/attributes.js b/src/attributes.js index b7c1f4a82..08bec5847 100644 --- a/src/attributes.js +++ b/src/attributes.js @@ -355,12 +355,12 @@ jQuery.extend({ var propName, attrNames, name, l, i = 0; - if ( elem.nodeType === 1 ) { - attrNames = ( value || "" ).split( rspace ); + if ( value && typeof value === "string" && elem.nodeType === 1 ) { + attrNames = jQuery.trim( value ).toLowerCase().split( " " ); l = attrNames.length; for ( ; i < l; i++ ) { - name = attrNames[ i ].toLowerCase(); + name = attrNames[ i ]; propName = jQuery.propFix[ name ] || name; // See #9699 for explanation of this approach (setting first, then removal) diff --git a/test/unit/attributes.js b/test/unit/attributes.js index f8305a28f..ac3de94bd 100644 --- a/test/unit/attributes.js +++ b/test/unit/attributes.js @@ -481,6 +481,41 @@ test("removeAttr(String)", function() { } }); +test("removeAttr, #", function() { + + var div = jQuery("<div />"); + + ok( div.removeAttr( "" ), "empty string" ); + ok( div.removeAttr(), "nothing" ); + ok( div.removeAttr( false ), "false" ); + ok( div.removeAttr( true ), "true" ); + ok( div.removeAttr({ }), "object" ); + ok( div.removeAttr( function(){} ), "function" ); + +}); + +test("removeAttr(Multi String)", function() { + expect(8); + + var div = jQuery("<div id='a' alt='b' title='c' rel='d'></div>"), + tests = { + id: "a", + alt: "b", + title: "c", + rel: "d" + }; + + jQuery.each( tests, function( key, val ) { + equal( div.attr(key), val, "Attribute `" + key + "` exists, and has a value of `" + val + "`" ); + }); + + div.removeAttr( "id alt title rel " ); + + jQuery.each( tests, function( key, val ) { + equal( div.attr(key), undefined, "Attribute `" + key + "` was removed" ); + }); +}); + test("prop(String, Object)", function() { expect(31); @@ -548,28 +583,6 @@ test("prop(String, Object)", function() { equal( $form.prop("enctype"), "multipart/form-data", "Set the enctype of a form (encoding in IE6/7 #6743)" ); }); -test("removeAttr(Multi String)", function() { - expect(8); - - var div = jQuery("<div id='a' alt='b' title='c' rel='d'></div>"), - tests = { - id: "a", - alt: "b", - title: "c", - rel: "d" - }; - - jQuery.each( tests, function( key, val ) { - equal( div.attr(key), val, "Attribute `" + key + "` exists, and has a value of `" + val + "`" ); - }); - - div.removeAttr( "id alt title rel" ); - - jQuery.each( tests, function( key, val ) { - equal( div.attr(key), undefined, "Attribute `" + key + "` was removed" ); - }); -}); - test("prop('tabindex')", function() { expect(8); |