checkbox is always "on" checkbox is always "on" jquery jquery

checkbox is always "on"


try $('#checkbox').is(':checked')


A checkbox's value is always 'on'. The HTML Form sends the value to the server only if the checkbox is checked. If the box is not checked, then the request parameter will be absent. This semantics is apparently to minimize the differences between checkboxes and radio buttons.

The HTML Form implements the following semantics:

if ($('#mycheckbox').is(':checked')) {    payload['mycheckbox'] = $('#mycheckbox').val();}

You can either mimic this semantics in Ajax or send the 'checked' flag directly as follows:

payload['mycheckbox'] = $('#mycheckbox').is(':checked');

I'd recommend mimic'ing the HTML Form semantics. Irrespective of what the client does, I'd recommend the following in the server code:

if mycheckbox param exists and its value is either 'true' or 'on' {  // pseudo code of course    // mycheckbox is checked} else {    // mycheckbox is unchecked}

Hope this explanation helps.


There is a pretty handy way to check all these element properties like disabled, checked, etc. with the prop function. This also converts it to boolean:

$('#checkbox').prop('checked'); // -> true/false$('#checkbox').prop('disabled'); // -> true/false