У меня есть модель просмотра MVC3, определяемая как:
[Validator(typeof(AccountsValidator))]
public class AccountViewModel
{
public List<string> Accounts { get; set; }
}
С помощью проверки, определенной с использованием FluentValidation (v3.3.1.0), как:
public class AccountsValidator : AbstractValidator<AccountViewModel>
{
public AccountsValidator()
{
RuleFor(x => x.Accounts).SetCollectionValidator(new AccountValidator()); //This won't work
}
}
Возможно, будет определена проверка учетной записи:
public class AccountValidator : AbstractValidator<string> {
public OrderValidator() {
RuleFor(x => x).NotNull();
//any other validation here
}
}
Я хотел бы, чтобы каждая учетная запись в списке была оценена, как описано в documentation. Однако вызов SetCollectionValidator
не работает, поскольку это не является опцией при использовании List<string>
, хотя опция была бы там, если она была определена как List<Account>
. Я что-то упускаю? Я мог бы изменить мою модель на использование List<Account>
, а затем определить класс Account, но я действительно не хочу менять свою модель в соответствии с валидацией.
Для справки, это представление, которое я использую:
@model MvcApplication9.Models.AccountViewModel
@using (Html.BeginForm())
{
@*The first account number is a required field.*@
<li>Account number* @Html.EditorFor(m => m.Accounts[0].Account) @Html.ValidationMessageFor(m => m.Accounts[0].Account)</li>
for (int i = 1; i < Model.Accounts.Count; i++)
{
<li>Account number @Html.EditorFor(m => m.Accounts[i].Account) @Html.ValidationMessageFor(m => m.Accounts[i].Account)</li>
}
<input type="submit" value="Add more..." name="add"/>
<input type="submit" value="Continue" name="next"/>
}