Set the property corresponding to a boolean attribute when setting to true. Fixes #9103.

- Once boolean properties had been modified natively, setting the attribute no longer set the current value
This commit is contained in:
timmywil 2011-05-04 15:53:00 -04:00
parent 3ed4b22073
commit 5195335cf4
2 changed files with 8 additions and 3 deletions

View file

@ -301,7 +301,7 @@ jQuery.extend({
return jQuery( elem )[ name ]( value );
}
var ret, hooks,
var ret, hooks, boolProp,
notxml = nType !== 1 || !jQuery.isXMLDoc( elem );
// Normalize the name if needed
@ -326,7 +326,12 @@ jQuery.extend({
} else {
// Set boolean attributes to the same name
// Also set the DOM property
if ( value === true && !rspecial.test( name ) ) {
boolProp = jQuery.propFix[ name ] || name;
if ( !rinvalidChar.test( boolProp ) && typeof elem[ boolProp ] === "boolean" ) {
elem[ boolProp ] = true;
}
value = name.toLowerCase();
}
@ -338,7 +343,6 @@ jQuery.extend({
return hooks.get( elem, name );
} else {
var boolProp;
// Align boolean attributes with corresponding properties
// Do not check the property if the name contains characters

View file

@ -163,7 +163,8 @@ test("attr(String, Object)", function() {
equals( jQuery("#name").attr("name"), "something", "Set name attribute" );
jQuery("#name").attr("name", null);
equals( jQuery("#name").attr("name"), undefined, "Remove name attribute" );
jQuery("#check2").attr("checked", true);
jQuery("#check2").prop("checked", true).prop("checked", false).attr("checked", true);
equals( document.getElementById("check2").checked, true, "Set checked attribute" );
equals( jQuery("#check2").prop("checked"), true, "Set checked attribute" );
equals( jQuery("#check2").attr("checked"), "checked", "Set checked attribute" );