2

我在输入表单中有其他字段和下拉列表。他们都验证得很好。即使没有正确验证前端的两个元素仍然可以正确地在帖子中绑定模型。我不完全确定他们为什么不验证。这是设置:

视图模型

public class DataVM
{
 //Widgets used, populated from database
 public List<Widget> Widgets { get; set; } 

 //Contains data to populate a dropdown with
 public GenericSelectList Containers { get; set; }

 //This will hold the relation between the widget and container
 //where widget is the local id, and container foreign id
 public List<NestedDictionary> WidgetContainers { get; set; }
}

public class NestedDictionary
{
    [RegularExpression("/^[1-9][0-9]*$/")]
    [Required]//This is not being enforced
    public int? ForeignId { get; set; }

    public int LocalId { get; set; }
}

看法

@for (int i = 0; i < Model.Widgets.Count; i++)
{
 @Html.Hidden("WidgetContainers["+i+"].LocalId", Model.Widgets.ElementAt(i).WidgetId)
 <div>
  <div>
   <span>Container Used</span><hr />
  </div>
  <div class="editor-field">
   @Html.DropDownListFor(
    m => m.WidgetContainers.ElementAt(i).ForeignId,
    new SelectList(
     Model.Containers.Values,
     "Id",
     "DisplayFields",
     0
    ),
    " - Select A Container - "
   )
   <br />@Html.ValidationMessageFor(model => model.WidgetContainers.ElementAt(i).ForeignId)
  </div>
 </div>
}

一切都显示得很好。它是交互式的,值是正确的。发布时,正确的数据将传递到正确的位置。但是,如果没有选择 Container,那么 post 就很好了,值为0pass。这里有点不知所措。任何想法为什么验证在客户端不起作用?

编辑

这是隐藏输入的渲染 html 和 select 元素

隐:

<input id="WidgetContainers_0__LocalId" type="hidden" value="39" name="WidgetContainers[0].LocalId">

选择:

<select name="ForeignId" id="ForeignId" class="valid">

显然,选择应该定义不同的属性。

编辑#2

如果我使用

m => m.WidgetContainers[i].ForeignId,

然后我得到

<select id="WidgetContainers_0__ForeignId" name="WidgetContainers[0].ForeignId" class="valid">
4

1 回答 1

-1

因为它根本不为空。如果您希望客户端验证正常工作,您应该允许它ForeignId为空而不是0 当您首先创建 DropDown 时

new SelectList(
 Model.Containers.Values,
 "Id",
 "DisplayFields",
 0 // Don't set this default value
)
于 2012-12-16T22:01:52.597 回答