我试图理解一些事情。
来自这篇博文http://bradwilson.typepad.com/blog/2010/10/mvc3-unobtrusive-validation.html
桥接 HTML 和 jQuery Validate:适配器
编写客户端验证器涉及两个步骤:为 jQuery Validate 编写验证器,以及编写从 HTML 属性中获取参数值并将其转换为 jQuery Validate 元数据的适配器。前一个主题不在这篇博文的范围内(因为它实际上不是 MVC 特定的)。
jQuery.validator.unobtrusive.adapters 中有一个适配器集合。挂在适配器集合之外的是适配器注册方法 (add) 和三个可用于注册非常常见的适配器类型的助手(addBool、addSingleVal 和 addMinMax)。
请注意,它说两个步骤。
但是如果你看一下这篇文章MVC3: make checkbox required via jQuery validate? 您只需要第二步(“编写适配器”)即可进行验证 - 通过添加以下代码行:
$.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>
}
所以基本上我有三个问题:
是 $.validator.unobtrusive.adapters.addBool("mandatory", "required"); 除了编写属性类之外,您真的唯一需要的东西吗?
它在幕后究竟做了什么?
我在哪里可以找到关于 addBool 的好文档?