Я реализую собственный валидатор, чтобы проверить, проверено ли хотя бы что-то:
public class AtLestOneRequiredAttribute : RequiredAttribute
{
public override bool IsValid(object value)
{
return (value != null);
}
}
public class RequiredListValidator : DataAnnotationsModelValidator<AtLestOneRequiredAttribute>
{
private readonly string errorMessage;
/// <summary>
/// Initializes a new instance of the <see cref="EmailValidator"/> class.
/// </summary>
/// <param name="metadata">The metadata.</param>
/// <param name="context">The context.</param>
/// <param name="attribute">The attribute.</param>
public RequiredListValidator(ModelMetadata metadata, ControllerContext context, AtLestOneRequiredAttribute attribute)
: base(metadata, context, attribute)
{
this.errorMessage = attribute.ErrorMessage;
}
/// <summary>
/// Retrieves a collection of client validation rules.
/// </summary>
/// <returns>A collection of client validation rules.</returns>
public override IEnumerable<ModelClientValidationRule> GetClientValidationRules()
{
var rule = new ModelClientValidationRule
{
ErrorMessage = errorMessage,
ValidationType = "atlestonerequired"
};
return new[] { rule };
}
}
Я также генерирую ненавязчивые атрибуты проверки для этого выбора (http://weblogs.asp.net/srkirkland/archive/2011/03/08/adding-unobtrusive-validation-to-mvccontrib-fluent-html.aspx)
Модель:
[AtLestOneRequired(ErrorMessage="At least one selection required")]
public IList<int> MyCheckBox{ get; set; }
Вид:
@this.CheckBoxList(x => x.MyCheckBox).Options(Model.MyCheckBoxes).IncludeUnobtrusiveValidationAttributes(Html)
В результате я получаю этот HTML с ненавязчивыми атрибутами в:
<div data-val="true" data-val-atlestonerequired="At least one selection required" id="MyCheckBox">
<input id="MyCheckBox_0" name="MyCheckBox" type="checkbox" value="1"/>
<label for="MyCheckBox_0" id="MyCheckBox_0_Label">A</label>
<input id="MyCheckBox_1" name="MyCheckBox" type="checkbox" value="2"/>
<label for="MyCheckBox_1" id="MyCheckBox_1_Label">B</label>
<input id="MyCheckBox_2" name="MyCheckBox" type="checkbox" value="3"/>
<label for="MyCheckBox_2" id="MyCheckBox_2_Label">C</label>
<input id="MyCheckBox_3" name="MyCheckBox" type="checkbox" value="4"/>
<label for="MyCheckBox_3" id="MyCheckBox_3_Label">D</label>
....
</div>
Но моя валидация не работает на стороне клиента, что мне нужно сделать, чтобы это работало? Я думаю, может быть, мне нужно реализовать пользовательский метод проверки JQuery в этом случае, если по умолчанию он не работает?
пытался добавить это:
jQuery.validator.addMethod("atlestonerequired", function (value, element) {
return (value != null);
});
jQuery.validator.unobtrusive.adapters.addBool('atlestonerequired');
не работает.