Made sure that the .val() logic for setting radios and checkboxes was correct. Fixes #5698.
This commit is contained in:
parent
261b7efb5f
commit
f298cce100
2 changed files with 18 additions and 2 deletions
|
@ -158,7 +158,7 @@ jQuery.fn.extend({
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( jQuery.isArray(val) && /radio|checkbox/.test( this.type ) ) {
|
if ( jQuery.isArray(val) && /radio|checkbox/.test( this.type ) ) {
|
||||||
this.checked = jQuery.inArray(this.value || this.name, val) >= 0;
|
this.checked = jQuery.inArray( this.value, val ) >= 0;
|
||||||
|
|
||||||
} else if ( jQuery.nodeName( this, "select" ) ) {
|
} else if ( jQuery.nodeName( this, "select" ) ) {
|
||||||
var values = jQuery.makeArray(val);
|
var values = jQuery.makeArray(val);
|
||||||
|
|
|
@ -619,7 +619,7 @@ test("clone() on XML nodes", function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
test("val()", function() {
|
test("val()", function() {
|
||||||
expect(11);
|
expect(15);
|
||||||
|
|
||||||
document.getElementById('text1').value = "bla";
|
document.getElementById('text1').value = "bla";
|
||||||
equals( jQuery("#text1").val(), "bla", "Check for modified value of input element" );
|
equals( jQuery("#text1").val(), "bla", "Check for modified value of input element" );
|
||||||
|
@ -646,6 +646,22 @@ test("val()", function() {
|
||||||
jQuery('#select3').val("");
|
jQuery('#select3').val("");
|
||||||
same( jQuery('#select3').val(), [''], 'Call val() on a multiple="multiple" select' );
|
same( jQuery('#select3').val(), [''], 'Call val() on a multiple="multiple" select' );
|
||||||
|
|
||||||
|
var checks = jQuery("<input type='checkbox' name='test' value='1'/>").appendTo("#form")
|
||||||
|
.add( jQuery("<input type='checkbox' name='test' value='2'/>").appendTo("#form") )
|
||||||
|
.add( jQuery("<input type='checkbox' name='test' value=''/>").appendTo("#form") );
|
||||||
|
|
||||||
|
same( checks.serialize(), "", "Get unchecked values." );
|
||||||
|
|
||||||
|
checks.val([ "2" ]);
|
||||||
|
same( checks.serialize(), "test=2", "Get a single checked value." );
|
||||||
|
|
||||||
|
checks.val([ "1", "" ]);
|
||||||
|
same( checks.serialize(), "test=1&test=", "Get multiple checked values." );
|
||||||
|
|
||||||
|
checks.val([ "", "2" ]);
|
||||||
|
same( checks.serialize(), "test=2&test=", "Get multiple checked values." );
|
||||||
|
|
||||||
|
checks.remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
var testVal = function(valueObj) {
|
var testVal = function(valueObj) {
|
||||||
|
|
Loading…
Reference in a new issue