我在试着理解一些事情。
从这个博客http://bradwilson.typepad.com/blog/2010/10/mvc3-unobtrusive-validation.html
连接HTML和jQuery验证:适配器 编写客户端验证程序需要两个步骤:编写用于jQuery验证的验证器;编写适配器,从jQuery属性获取参数值并将其转化为jQuery验证元数据。前一个主题不在这篇博客文章的范围内(因为它实际上不是MVC特定的)。 在jQuery.validator.unobtrusive.adapters有一个适配器集合可用。挂起适配器集合的是适配器注册方法(add)和三个帮助程序,它们可以用于注册非常常见类型的适配器(addBool、addSingleVal和addMinMax)。
注意,它说有两个步骤。
但是,如果您查看这篇文章MVC3:通过jQuery验证所需的复选框?,您只需要第二步(“编写适配器”)才能使验证工作--添加以下代码:
$.validator.unobtrusive.adapters.addBool("mandatory", "required");
我在一个新的MVC 4 Internet应用程序中测试了代码,它运行得很好,下面是一个超级简单的示例。
视图模型
public class SimpleViewModel
{
[Mandatory(ErrorMessage = "You must agree to the Terms to register.")]
[Display(Name = "Terms Accepted")]
public bool IsTermsAccepted { get; set; }
}
验证属性
public class MandatoryAttribute : ValidationAttribute, IClientValidatable
{
public override bool IsValid(object value)
{
return (!(value is bool) || (bool)value);
}
public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
{
ModelClientValidationRule rule = new ModelClientValidationRule();
rule.ErrorMessage = FormatErrorMessage(metadata.GetDisplayName());
rule.ValidationType = "mandatory";
yield return rule;
}
}
视图
@model MvcApplication2.Models.SimpleViewModel
@{
ViewBag.Title = "";
}
@using (Html.BeginForm()) {
@Html.ValidationSummary()
@Html.CheckBoxFor(model => model.IsTermsAccepted)
@Html.ValidationMessageFor(model => model.IsTermsAccepted)
<input type="submit" value="Send" />
}
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
<script type="text/javascript">
$.validator.unobtrusive.adapters.addBool("mandatory", "required");
</script>
}
基本上,我有三个问题:
发布于 2013-01-25 13:29:26
除了评论中链接到的@BlueChippy的文章外,我还在这篇文章中找到了第2条的答案。
这只是为MandatoryAttribute注册了一个新的验证适配器,其中第一个参数是适配器名,第二个参数是jQuery验证规则的名称。适配器名称应该与我们前面指定的值匹配为验证类型,而jQuery验证所需的规则将要求用户选中复选框。
3.更多信息可以在布拉德·威尔逊博客上的这篇文章中找到。
https://stackoverflow.com/questions/11978990
复制相似问题