这是我的模特
public class ContractsViewModel
{
public int Id { get; set; }
public string Code { get; set; }
public List<ContractProductItemViewModel> Products { get; set; }
public ContractsViewModel()
{
this.Products = new List<ContractProductItemViewModel>();
}
}
public class ContractProductItemViewModel
{
public int Id { get; set; }
[Required]
public int? ProductId { get; set; }
[Required]
public double Price { get; set; }
[Required]
public int Quantity { get; set; }
}
这是合约视图:
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<div class="fieldset">
<div class="editor-label">
@Html.LabelFor(model => model.Code)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Code)
@Html.ValidationMessageFor(model => model.Code)
</div>
<div class="new-detailitem">
<div class="new-icon"></div>
<div>Crear Nuevo</div>
</div>
<div>
<table class="tblindex detail">
<thead>
<td class="quantity">Cantidad</td>
<td>Grupo</td>
<td>Articulo</td>
<td class="price">Precio</td>
<td>SubTotal</td>
<td></td>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
}
这是productDetail视图
@{
Layout = null;
if (this.ViewContext.FormContext == null)
{
this.ViewContext.FormContext = new FormContext();
}
}
<tr>
<td class="quantity">
@Html.TextBoxFor(model => model.Quantity)
@Html.ValidationMessageFor(model => model.Quantity)
</td>
<td class="category"></td>
<td class="product">
<div>
<span style="float:left"></span>
@Html.HiddenFor(model => model.ProductId)
<div class="getitem"></div>
<div style="clear: both"></div>
</div>
@Html.ValidationMessageFor(model => model.ProductId)
</td>
<td class="price">
@Html.EditorFor(model => model.Price)
@Html.ValidationMessageFor(model => model.Price)
</td>
<td>0.00</td>
<td><div class="removeicon"/></td>
</tr>
我用jquery ajax以编程方式添加每个项目详细信息行。
我有一个问题,productdetail视图中的html.EditorFor和ValidationMessageFor为每一行生成相同的id,而在客户端中,事件的处理方式不正确。
我在这里做错了什么? 解决这个问题的最佳方法是什么?
感谢