So this one is done on request and because I am a kind of merciful god I will grant this request.
For those bullet point programmers:
Now when I say validation, I mean the validation plugin. and this example is built using concepts in this post.
Here’s the markup:
<form id="formCheckBoxValidation" method="post" action="checkboxValidation.html">
<input type="checkbox" id="checkBoxList" name="checkBoxList" value="One">
<input type="checkbox" id="checkBoxList" name="checkBoxList" value="Two">
<input type="checkbox" id="checkBoxList" name="checkBoxList" value="Three">
<input type="checkbox" id="checkBoxList" name="checkBoxList" value="Four">
<input type="checkbox" id="checkBoxList" name="checkBoxList" value="Five">
<br />
<input type="submit" id="buttonCheckBoxValidation">
</form>
<div>
<div id="divError" name="divError" style="display:none;"></div>
</div>
<form id="formCheckBoxValidationDifferentName" method="post" action="checkboxValidation.html">
<input type="checkbox" id="checkBoxListOne" name="checkBoxListOne" value="One">
<input type="checkbox" id="checkBoxListTwo" name="checkBoxListTwo" value="Two">
<input type="checkbox" id="checkBoxListThree" name="checkBoxListThree" value="Three">
<br />
<input type="submit" id="buttonCheckBoxValidationDifferentName">
</form>
<div>
<div id="divErrorDifferentName" name="divErrorDifferentName" style="display:none;"></div>
</div>
For this example I’m actually presenting two examples(Say ‘example’ again, I dare you, I double dare you m—erf—er, say ‘example’ one more God d–n time!): If the checkboxes are linked by id and if the checkboxes are not linked at all. There is actually a difference. You see, if they share the same id, the required method can be used since it will treat them all as the same element and therefore if even on is checked, there is a value. Otherwise, you have to check all the checkboxes to see if at least one is checked. (Yeah, that made total sense.)
Here’s the check checkboxes method:
//Add a method to the validator that checks to see if at least one of the
// three checkboxes specified are checked.
jQuery.validator.addMethod(‘atLeastOneChecked’, function(value, element) {
var checkedCount = 0;
if (jQuery(‘#checkBoxListOne’).is(‘:checked’)){
checkedCount += 1;
}
if (jQuery(‘#checkBoxListTwo’).is(‘:checked’)){
checkedCount += 1;
}
if (jQuery(‘#checkBoxListThree’).is(‘:checked’)){
checkedCount += 1;
}
return checkedCount > 0;
});
Oooooh baby.
Now for setting up the validation:
//This is for the first checkbox area where every checkbox has the same id causing them
// to be a group and therefore the default required works.
var validationRules = new Object();
validationRules['checkBoxList'] = {required:true};
var validationMessages = new Object();
validationMessages['checkBoxList'] = {required:'at least one has be checked.'};
jQuery('#formCheckBoxValidation').validate({
errorLabelContainer: '#divError',
wrapper: 'div',
rules: validationRules,
messages: validationMessages,
onfocusout: false,
onkeyup: false,
submitHandler: function (label) {
alert('hooray');
}
});
//This is for the second checkbox area where every checkbox has a different name
// and therefore the atLeastOneChecked method must be used.
validationRules = new Object();
validationRules['checkBoxListOne'] = {atLeastOneChecked:true};
validationMessages = new Object();
validationMessages['checkBoxListOne'] = {atLeastOneChecked:'at least one has be checked.'};
jQuery('#formCheckBoxValidationDifferentName').validate({
errorLabelContainer: '#divErrorDifferentName',
wrapper: 'div',
rules: validationRules,
messages: validationMessages,
onfocusout: false,
onkeyup: false,
submitHandler: function (label) {
alert('hooray');
}
});
In the words of Q-Bert: @#$% yeah!