我在输入表单中有其他字段和下拉列表。他们都验证得很好。即使没有正确验证前端的两个元素仍然可以正确地在帖子中绑定模型。我不完全确定他们为什么不验证。这是设置:
视图模型
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 就很好了,值为0
pass。这里有点不知所措。任何想法为什么验证在客户端不起作用?
编辑
这是隐藏输入的渲染 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">