简而言之 - 在我的视图中,仅为来自集合的第一个对象的输入添加数据验证属性。我希望能够在我的View上验证集合中任何对象的输入。我使用的是Asp.net MVC4,jquery.validate.unobtrusive。
更详细: 我的项目中有一个管理页面,我想要显示所有产品类别。可以编辑任何此类别。在编辑过程结束时,用户可以单击按钮保存所有更改。
我的ViewModel:
public class CategoriesManagementViewModel
{
[Required(ErrorMessage = Validation.FieldRequiredMsg)]
public int Id { get; set; }
[Required(ErrorMessage = Validation.FieldRequiredMsg)]
[StringLength(50, ErrorMessage = Validation.MaxLength50Msg)]
public string Name { get; set; }
[Required(ErrorMessage = Validation.FieldRequiredMsg)]
[Range(0, int.MaxValue, ErrorMessage = Validation.PositiveNumberMsg)]
public int AmountForDiscount { get; set; }
[Required(ErrorMessage = Validation.FieldRequiredMsg)]
[Range(0, 100, ErrorMessage = Validation.PercentMsg )]
public int DiscountPercent { get; set; }
public bool IsActive { get; set; }
}
这是控制器:
public JsonResult GetProductCategories(int currentPage)
{
using (var service = new DalServiceSoapClient())
{
var data = service.GetProductCategories(currentPage, Constants.ItemsOnPage,false)
.Select(x=> new CategoriesManagementViewModel(x));
var html = RenderRazorViewToString("_ManageCategoriesPartial", data);
return Json(new { status = "success", html = html });
}
}
在控制器中我从db获取数据,将其转换为我的ViewModel集合并传递给Partial View。部分视图呈现为html字符串,以json形式发送,并且我的视图的一部分已更新。
以下是部分观点:
@model IEnumerable<GreenLightShop.Models.CategoriesManagementViewModel>
@{
Layout = null;
var i = 0;
}
@foreach (var item in Model)
{
var blockedClass = "";
var blockBtnCaption = "Block";
if (!item.IsActive)
{
blockedClass = "blocked";
blockBtnCaption = "UnBlock";
}
<div class='box @blockedClass' itemid="@item.Id" ischanged="false" isactive ="@item.IsActive">
<div class="show">
<span>@item.Name</span>
| <a href="#" class="edit-category-btn">Edit Category</a>
| <a href="#" class="edit-products-btn">Edit Product</a>
| <a href="#" class="block-btn"> @blockBtnCaption </a> |
</div>
<form class="edit hidden">
<div class="form-field">
<label> Name:</label>
@Html.TextBoxFor(x => x.ElementAt(i).Name)
@* @Html.HiddenFor(x=>x.ElementAt(i).Name)*@
<div>
@Html.ValidationMessageFor(x => x.ElementAt(i).Name)
</div>
</div>
<div class="form-field">
<label> Amount For Discount:</label>
@Html.TextBoxFor(x => x.ElementAt(i).AmountForDiscount)
@* @Html.HiddenFor(x => x.ElementAt(i).AmountForDiscount)*@
<div>
@Html.ValidationMessageFor(x => x.ElementAt(i).AmountForDiscount)
</div>
</div>
<div class="form-field">
<label> Discount:</label>
@Html.TextBoxFor(x => x.ElementAt(i).DiscountPercent)
@* @Html.HiddenFor(x => x.ElementAt(i).DiscountPercent)*@
<div>
@Html.ValidationMessageFor(x => x.ElementAt(i).DiscountPercent)
</div>
</div>
<input type="button" class="accept-changes-btn" value="Apply"/>
<input type="button" class="cancel-changes-btn" value="Cancel"/>
</form>
</div>
i++;
}
对于第一个元素
IEnumerable<GreenLightShop.Models.CategoriesManagementViewModel>
,验证属性被添加到表单上的每个输入。
<input id="Name" type="text" value="CategoryName" name="Name" data-val-required="This field is required." data-val-length-max="50" data-val-length="Not longer than 50 characters." data-val="true">.
验证工作正常。
对于所有其他类别的输入,不会添加验证属性。
<input id="Name" type="text" value="AnotherCategory" name="Name">
用户点击
<input type="button" class="accept-changes-btn" value="Apply"/>`,
我正在使用$.validator.unobtrusive.parse($(this));
所有类别都正常显示,当我提交更改时,Model.IsValid工作正常,数据绑定也可以。
如何为每个类别进行验证?
提前致谢。
答案 0 :(得分:0)
以下是我找到的解决方案:
问题是我使用<Form>
标签的每个表单。当我将其更改为@using(Html.BeginForm())
时问题得到解决。现在,我视图中每个表单中的每个输入都有验证属性。
如果有人知道这个解释,为什么会这样,我很乐意听到。