使用 MVC 3(不显眼的 ajax)对整个模型进行客户端验证

Client-Side Validation for entire model using MVC 3 (unobtrusive ajax)

提问人:TheDude 提问时间:7/28/2012 最后编辑:Yasser ShaikhTheDude 更新时间:9/1/2012 访问量:1392

问:

我已经为单个属性进行了客户端验证,但是,我想使用客户端验证在模型级别(2 个或更多属性)进行验证。

我用于显示我创建的 Model 属性的验证错误。@Html.ValidationSummary(true)

但是,生成模型错误时,它不会显示消息。它会阻止执行操作,但不会显示任何错误。

有人知道为什么会这样吗?

我的直觉是它与客户端验证有关,因为在这种情况下服务器端不起作用,因为我必须使用 Ajax 表单。

任何建议将不胜感激!

模型属性

public class AuditDetailValidatorAttribute : ValidationAttribute, IClientValidatable
{
    public AuditDetailValidatorAttribute()
    {
        ErrorMessage = "Must select an NCN level...";
    }

    public override bool IsValid(object value)
    {
        AuditRequirementDetail audit = value as AuditRequirementDetail;

        if (audit == null || audit.AuditResult.Id == 0 || audit.AssessmentLevel.Id == 0)
        {
            return true;
        }
        else
        {
            return !(audit.AuditResult.Id == 4 && audit.AssessmentLevel.Id == 1);
        }
    }

    public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
    {
        return new List<ModelClientValidationRule> 
        {
            new ModelClientValidationRule 
            {
                ValidationType = "required",
                ErrorMessage = this.ErrorMessage
            }
        };
    }
}

模型类

    [AuditDetailValidator]
    public class AuditRequirementDetail
    {
        // Constructor
        public AuditRequirementDetail()
        {
            // instantiate the contained objects on AuditRequirementDetail creation
            AssessmentLevel = new AssessmentLevel();
            AuditResult = new AuditResult();
            Requirement = new RequirementDetail();
            Attachment = new Attachment();

            Counter = 0;
        }
        /* rest of the code */
     }

视图

@model pdiqc.Models.AuditRequirement.AuditRequirementDetail

@{
    var SuccessTarget = "success" + Model.DetailID;
    var IsValidTarget = "IsValid" + Model.DetailID;
    var PerformCompletedTarget = "PerformCompleted" + Model.DetailID;
    var AuditResultTarget = "AuditResult_Id" + Model.DetailID;
    var AssessmentLevelTarget = "AssessmentLevel_Id" + Model.DetailID;
    var DesignatorTarget = "Designator_Id" + Model.DetailID;
    var EvidenceTarget = "Evidence_Id" + Model.DetailID;
    var AttachmentTarget = "Attachments_Id" + Model.DetailID;

    var AuditResultReferral = "#" + AuditResultTarget;
    var AssessmentLevelReferral = "#" + AssessmentLevelTarget;
    var DesignatorReferral = "#" + DesignatorTarget;
    var EvidenceReferral = "#" + EvidenceTarget;
    var AttachmentReferral = "#" + AttachmentTarget;
}

    @using (Ajax.BeginForm("PerformRequirement", "Audit", new AjaxOptions { HttpMethod = "POST", OnSuccess = "success" }, new {Class="PerformReqForm" }))
    {
        @Html.ValidationSummary(true)
        if ((Model.AuditResult.Id == 1 && Model.AssessmentLevel.Id > 1) || Model.Evidence == string.Empty || Model.Evidence == null)
        {
            <input class="@IsValidTarget" name="IsValid" type="hidden" value=false />
        }
        else
        {
            <input class="@IsValidTarget" name="IsValid" type="hidden" value=true />
        }

       <p class="reqText">@Model.RequirementLabel.ConfigurableLabelDesc #@ViewBag.PerformCounter - @ModelMetadata.FromLambdaExpression(x => x.Requirement.Text, ViewData).SimpleDisplayText</p>
       <div class="hide">
       /* REST OF CODE */
    }
HTML ASP.NET-MVC-3 验证 客户端 unobtrusive-javascript

评论

0赞 Yasser Shaikh 7/28/2012
要对其应用验证的属性是什么?
0赞 TheDude 7/28/2012
以下是我正在验证的属性: 返回 !(audit.AuditResult.Id == 4 && audit.AssessmentLevel.Id == 1);
0赞 TheDude 7/28/2012
基本上,如果“auditresult.id”是 4,audit.assessmentlevel.id 是 1,则模型无效。
0赞 Yasser Shaikh 7/28/2012
您是否尝试过在方法中添加断点并检查它是否按您的意愿工作?IsValid()
1赞 TheDude 7/28/2012
好吧,我知道它正在起作用。成功后,它会成功写入数据库。我上面的验证阻止它写入数据库。问题是错误消息不显示。因此,当您单击提交按钮时,什么也没发生。我希望显示一条错误消息。

答:

0赞 Code Jammr 9/1/2012 #1

我为一个复选框编写了一个自定义验证器,以确保它是厚脸皮的,并且必须执行以下操作。

<script type="text/javascript">
    $(function() {
        $.validator.unobtrusive.adapters.addBool('requiredcheckbox', 'required');
    }(jQuery));
</script>

还包括 @Html.ValidationMessageFor(x=>x.yourProp)