如何将asp.net mvc3数据注释用于对象列表

时间:2012-12-24 13:06:33

标签: asp.net-mvc-3 razor data-annotations

这是我的模特

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,而在客户端中,事件的处理方式不正确。

我在这里做错了什么? 解决这个问题的最佳方法是什么?

感谢

0 个答案:

没有答案