Como posso validar o resultado em um modelo de editor do ASP.NET MVC?
-
23-09-2019 - |
Pergunta
Eu criei um modelo de editor para representar a seleção de uma lista suspensa dinâmica e funciona como deveria, exceto para validação, que não consegui descobrir. Se o modelo tiver o [Required]
Conjunto de atributos, quero que isso invalide se a opção padrão for selecionada.
O objeto de modelo de vista que deve ser representado como a lista suspensa é Selector
:
public class Selector
{
public int SelectedId { get; set; }
public IEnumerable<Pair<int, string>> Choices { get; private set; }
public string DefaultValue { get; set; }
public Selector()
{
//For binding the object on Post
}
public Selector(IEnumerable<Pair<int, string>> choices, string defaultValue)
{
DefaultValue = defaultValue;
Choices = choices;
}
}
O modelo do editor se parece com o seguinte:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl" %>
<select class="template-selector" id="<%= ViewData.ModelMetadata.PropertyName %>.SelectedId" name="<%= ViewData.ModelMetadata.PropertyName %>.SelectedId">
<%
var model = ViewData.ModelMetadata.Model as QASW.Web.Mvc.Selector;
if (model != null)
{
%>
<option><%= model.DefaultValue %></option><%
foreach (var choice in model.Choices)
{
%>
<option value="<%= choice.Value1 %>"><%= choice.Value2 %></option><%
}
}
%>
</select>
Eu meio que consegui funcionar chamando -o da visão como esta (onde Category
é um Selector
):
<%= Html.ValidationMessageFor(n => n.Category.SelectedId)%>
Mas mostra o erro de validação para não fornecer um número adequado e não se importa se eu definir o Required
atributo.
Solução
Encontrei uma solução em que a validação é feita contra campos ocultos usando regras de validação personalizadas, aqui. Usando essa abordagem, você pode adicionar facilmente validação personalizada aos tipos arbitrários.
Outras dicas
Por que o seu modelo de editor não é fortemente digitado?
<%@ Control Language="C#"
Inherits="System.Web.Mvc.ViewUserControl<QASW.Web.Mvc.Selector>" %>
Por que não usar a lista suspensa para ajudante:
<%= Html.DropDownListFor(
x => x.SelectedId,
new SelectList(Model.Choices, "Value1", "Value2")
)%>
Para evitar as cordas mágicas, você pode adicionar uma propriedade Choics -List ao seu modelo de visualização:
public IEnumerable<SelectListItem> ChoicesList
{
get
{
return Choices.Select(x => new SelectListItem
{
Value = x.Value1.ToString(),
Text = x.Value2
});
}
}
e prenda seu ajudante a ele:
<%= Html.DropDownListFor(x => x.SelectedId, Model.ChoicesList) %>