0

我的问题是

我想在客户端和服务器端的 mvc3 中进行验证。

我知道如何在服务器端使用验证,但客户端验证有问题。

假设我有一个带有剃须刀的文本框

**Email : @html.Textboxfor(m=>m.Email)**

或者

所以错误会像这个 无效的电子邮件一样显示

现在我想在客户端和服务器端验证电子邮件。

对于客户端,我想使用我的 owan javascript file.on 提交表单首先验证

在客户端,如果它验证然后表单将提交并且服务器端的验证将不会检查。但是如果用户从浏览器中禁用脚本而不是服务器端验证将被执行,

4

1 回答 1

0

服务器端验证应始终启用并且比客户端验证更强大。有些事情在客户端可能难以验证,例如模型或模型属性之间的复杂交互。但是,您可以使用jQuery验证器插件(VS MVC 项目模板附带)进行客户端验证。您在服务器上有验证属性,该属性实现IClientValidatable

public class MyValidationAttribute : ValidationAttribute, IClientValidatable
{

    public override bool IsValid(object value)
    {
        if (value == null) {
            return true;
        }
        //Add validation rules
        if (false) {
            return false;
        }
        return true;
    }

    public override string FormatErrorMessage(string name)
    {
        return "Please provide valid values."
    }

    public IEnumerable<System.Web.Mvc.ModelClientValidationRule> GetClientValidationRules(System.Web.Mvc.ModelMetadata metadata, System.Web.Mvc.ControllerContext context)
    {
        return new ModelClientValidationRule[] { new ModelClientValidationRule {
            ErrorMessage = "Please provide valid values.",
            ValidationType = "validationrule"
        } };
    }
}

在客户端,您需要添加验证规则:

jQuery.validator.addMethod("validationrule", function (value, element, param) {
    if (value == "") {
        return false;
    }
    return true;
});
jQuery.validator.unobtrusive.adapters.addBool('validationrule');

确保将其添加到 jQuery 就绪处理程序之外。请参阅此问题的已接受答案。

于 2013-02-01T06:12:11.507 回答