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.

Foi útil?

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) %>
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top