実際のデモ for A / B / C
ケース: http://jsfiddle.net/hfLwB/
動作: 入力フィールドの 1 つに nu,her 値が設定されている限り、計算を実行できます。3 つのフィールドがすべて空の場合、エラーが発生します。.at_least_one
classとaddMthod:にも注意してくださいrequire_from_group
。
Anyhoo コードはより適切に話す必要があります。
良いリンク: http://docs.jquery.com/Plugins/Validation
それが役に立てば幸い :)
HTML
<form action="results.whatever" target="_blank" id="HULK">
<div style="clear:both">
<label for="a">A</label>
<div style="float:right">
<input name="a" type="text" class="at_least_one idleField"></div>
</div>
<div style="clear:both">
<label for="b">B</label>
<div style="float:right">
<input name="b" type="text" class="at_least_one idleField">
</div>
</div>
<div style="clear:both">
<label for="c">C</label>
<div style="float:right">
<input name="c" type="text" class="at_least_one idleField">
</div>
</div>
<div id="button">
<input name="" type="submit" value="Calculate" class="calc_button" style="cursor:hand">
</div>
</form>
<div id="errorContainer">
<h4>errors</h4>
<ol>
</ol>
</div>
コード
jQuery.validator.addMethod("require_from_group", function(value, element, options) {
var numberRequired = options[0];
var selector = options[1];
var fields = $(selector, element.form);
var filled_fields = fields.filter(function() {
// it's more clear to compare with empty string
return $(this).val() != "";
});
var empty_fields = fields.not(filled_fields);
// we will mark only first empty field as invalid
if (filled_fields.length < numberRequired && empty_fields[0] == element) {
return false;
}
return true;
// {0} below is the 0th item in the options field
}, jQuery.format("Please fill out at least {0} of these fields."));
$(document).ready(function(){
var container = $('#errorContainer');
$("#HULK").validate( {
// We must to force validation of entire form because
// when we remove value from 2-nd field
// the 1-st field becomes invalid.
onfocusout: function() { $("#HULK").valid() },
onkeyup: function() { $("#HULK").valid() },
rules: {
// note: you can use variable to avoid repeating
// of the same code
a: {
number: true,
require_from_group: [1, ".at_least_one"]
},
b: {
number: true,
require_from_group: [1,".at_least_one"]
},
c: {
number: true,
require_from_group: [1,".at_least_one"]
}
},
success: function(label) {
label.html(" ").addClass("checked");
},
errorContainer: container,
errorLabelContainer: $("ol", container),
wrapper: 'li',
meta: "validate"
});
});