使用不显眼的 javascript/MVC3 和 DataAnnotations 验证电子邮件地址

Validating an e-mail address with unobtrusive javascript / MVC3 and DataAnnotations

提问人:Dismissile 提问时间:5/27/2011 最后编辑:gligoranDismissile 更新时间:5/24/2017 访问量:17507

问:

jQuery 验证使验证电子邮件地址变得简单:

$("someForm").validate({
    rules: {
        SomeField: {
            required: true,
            email: true,
            remote: {
                type: "POST",
                url: "CheckEmail"
            }
        }
    }
});

这样一来,SomeField 是必需的,必须格式化为电子邮件地址,并且还执行对 CheckEmail 操作的远程调用(检查重复项)。

我喜欢让事情尽可能简单,这样我就可以使用数据注释做很多同样的事情:

public class RegisterModel {
    [Required]
    [Remote("CheckEmail", "Home", HttpMethod="POST")]
    public string SomeField { get; set; }
}

ASP.net MVC 3 / 数据注释是否具有内置/简单的验证方法,以确保电子邮件地址的格式正确?

如果可能的话,我希望它产生不显眼的javascript。

C# ASP.NET-MVC-3 数据批注 javascript 不显眼的 验证

评论

0赞 MaxPayne 10/13/2023
检查此示例:codingfusion.com/Post/...

答:

9赞 Darin Dimitrov 5/27/2011 #1

ASP.net MVC 3 / 数据注释吗 有一种内置/简单的验证方式 确保电子邮件地址位于 正确的格式?

不是内置的,但您可以使用 .Scott Gu 在一篇博文中举例说明了这种正则表达式。他写了一个源自的习惯,以避免重复逻辑。[RegularExpression]EmailAttributeRegularExpressionAttribute

评论

0赞 Dismissile 5/27/2011
假设我想编写自己的属性,例如 [Email]。我怎么能做到这一点并让它产生不显眼的javascript。你能为我指出正确的方向吗?
1赞 Darin Dimitrov 5/27/2011
@Dismissile,请查看 Scott Gu 博客文章。在其中,他从中派生,因此客户端验证将自动工作,因为 Regex 属性已经注册了一个 jquery 适配器。RegularExpressionAttribute
0赞 Dismissile 5/27/2011
很酷,谢谢。我浏览了一下,但我没有看到他实际上派生了它。
9赞 Vadim Lozinskiy 5/27/2011 #2

Data Annotation Extensions 库具有允许验证电子邮件地址的属性。[Email]

还有一篇博客文章概述了如何使用该库。

评论

2赞 Paul Prewett 10/14/2011
Vadim 的意思是,现在有一个 NuGet 包可用,其中包含用于电子邮件、日期、信用卡等的内置 DataAnnotations。很好。项目网址:dataannotationsextensions.org
11赞 Robert Corvus 5/28/2011 #3

我认为这是您正在寻找的代码(这类似于 ScottGu 的示例,但也在默认错误消息中显示 DisplayName,而不是属性名称):

public class EmailAttribute : RegularExpressionAttribute
{
    private const string defaultErrorMessage = "'{0}' must be a valid email address";

    public EmailAttribute() : 
        base("^[a-z0-9_\\+-]+(\\.[a-z0-9_\\+-]+)*@[a-z0-9]+(\\.[a-z0-9]+)*\\.([a-z]{2,4})$")
    { }

    public override string FormatErrorMessage(string name)
    {
        return string.Format(defaultErrorMessage, name);
    }

    protected override ValidationResult IsValid(object value,
                                            ValidationContext validationContext)
    {
        if (value != null)
        {
            if (!base.IsValid(value))
            {
                return new ValidationResult(
                    FormatErrorMessage(validationContext.DisplayName));
            }
        }

        return ValidationResult.Success;
    }
}

然后,模型属性将如下所示:

    [DisplayName("My Email Address")]
    [Email]
    public string EmailAddress { get; set; }
0赞 Matt 5/24/2017 #4

EmailAddress 属性已内置于框架中,无需数据注释扩展或其他逻辑:使用 DataAnnotations 和 DataType 进行电子邮件模型验证