MVC3 / Razor客户端验证未触发

时间:2011-02-07 23:22:00

标签: validation asp.net-mvc-3 client razor

我正在尝试使用数据注释在MVC3中进行客户端验证。我已经查看了类似的帖子,包括这个MVC3 Client side validation not working的答案。

我正在使用EF数据模型。我为我的验证创建了一个这样的部分类。

[MetadataType(typeof(Post_Validation))]
public partial class Post
{

}

public class Post_Validation
{
    [Required(ErrorMessage = "Title is required")]
    [StringLength(5, ErrorMessage = "Title may not be longer than 5 characters")]
    public string Title { get; set; }

    [Required(ErrorMessage = "Text is required")]
    [DataType(DataType.MultilineText)]
    public string Text { get; set; }

    [Required(ErrorMessage = "Publish Date is required")]
    [DataType(DataType.DateTime)]
    public DateTime PublishDate { get; set; }
}

我的cshtml页面包含以下内容。

<h2>Create</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>

@using (Html.BeginForm()) {
    @Html.ValidationSummary(true)
    <fieldset>
        <legend>Post</legend>

        <div class="editor-label">
            @Html.LabelFor(model => model.Title)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Title)
            @Html.ValidationMessageFor(model => model.Title)
        </div>

        <div class="editor-label">
            @Html.LabelFor(model => model.Text)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.Text)
            @Html.ValidationMessageFor(model => model.Text)
        </div>
}

Web配置:

<appSettings>
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />

布局:

<head>
<title>@ViewBag.Title</title>
<link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
<script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")" type="text/javascript"></script>

因此,多行文本注释可以工作并创建文本区域。但是没有一个验证工作在客户端。我不知道我可能会失踪什么。有任何想法吗??如果需要,我可以发布更多信息。谢谢!

2 个答案:

答案 0 :(得分:5)

1)。 尝试将以下内容添加到您要验证的视图中

HtmlHelper.ClientValidationEnabled = true;
HtmlHelper.UnobtrusiveJavaScriptEnabled = true;

我认为没有必要修改Web.config,因此您可以删除

<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
祝你好运!此外,尝试输入已知的错误值以查看是否触发了客户端验证,所需的注释似乎不足以显示空白输入的消息。

2)。 在视图中放置脚本,它应该可以工作。

@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}

答案 1 :(得分:-4)

尝试使用公共对象声明:

public class Post_Validation
{
    [Required(ErrorMessage = "Title is required")]
    [StringLength(5, ErrorMessage = "Title may not be longer than 5 characters")]
    public object Title { get; set; }

    [Required(ErrorMessage = "Text is required")]
    [DataType(DataType.MultilineText)]
    public object Text { get; set; }

    [Required(ErrorMessage = "Publish Date is required")]
    [DataType(DataType.DateTime)]
    public object PublishDate { get; set; }
}