MVC4表单输入验证 - 自定义错误范围

Owe*_*wen 4 validation asp.net-mvc asp.net-mvc-4

我有一个使用几个输入的表单,Html.TextBoxFor每个输入都有一个ValidationMessageForViewModel属性获取它的错误消息.对于这个例子,我们假装只有一个输入:

@Html.TextBoxFor(x => x.Code)
@Html.ValidationMessageFor(x => x.Code)
Run Code Online (Sandbox Code Playgroud)

当出现模型错误时,验证器会在几个跨度内显示它的错误消息,如下所示:

<input type="text" value="" name="Code" id="Code" data-val-required="Personalised code is required" data-val="true" class="input-validation-error">
<span data-valmsg-replace="true" data-valmsg-for="Code" class="field-validation-error">
    <span for="Code" generated="true" class="">Personalised code is required</span>
</span>
Run Code Online (Sandbox Code Playgroud)

如何自定义此错误消息?

例如,将外跨度更改为div并同时给出div和span clases?

<div class="myOuterSpan" data-valmsg-replace="true" data-valmsg-for="Code" class="field-validation-error">
    <span class="myInnerSpan" for="Code" generated="true" class="">Personalised code is required</span>
</div>
Run Code Online (Sandbox Code Playgroud)

或者只有一个跨度?

<span class="errorWrapper" for="Code" generated="true">Code is required</span>
Run Code Online (Sandbox Code Playgroud)

或者将整个地块包裹在div中?

<div class="myOuterDiv">
    <span data-valmsg-replace="true" data-valmsg-for="Code" class="field-validation-error">
        <span for="Code" generated="true" class="">Personalised code is required</span>
    </span>
</div>
Run Code Online (Sandbox Code Playgroud)

你明白了......

解决方案

我的解决方案基于Darin的答案并创建了一个CustomValidationMessage,而不是我最初打算创建的customValidationMessageFOR.

CONTROLLER

ModelState.AddModelError("Code", "Invalid Code");
Run Code Online (Sandbox Code Playgroud)

视图

@Html.CustomValidationMessage("Code")
Run Code Online (Sandbox Code Playgroud)

延期

public static class Extensions
{
    public static MvcHtmlString CustomValidationMessage(this HtmlHelper htmlHelper, string modelName)
    {
        var modelState = htmlHelper.ViewData.ModelState[modelName];
        var modelErrors = modelState == null ? null : modelState.Errors;
        var modelError = ((modelErrors == null) || (modelErrors.Count == 0))
            ? null
            : modelErrors.FirstOrDefault(e => !string.IsNullOrEmpty(e.ErrorMessage)) ?? modelErrors[0];

        if (modelError != null)
        {
            return MvcHtmlString.Create("<span class='validation_wrapper customValidation'><span>" + modelError.ErrorMessage +"</span></span>");
        }

        return new MvcHtmlString(string.Empty);
    }
}
Run Code Online (Sandbox Code Playgroud)

Dar*_*rov 5

无法修改ValidationMessageFor帮助程序生成的标记.如果你想这样做,你将不得不写一个自定义助手.以下是此帮助程序的签名可能如下所示:

public static MvcHtmlString CustomValidationMessageFor<TModel, TProperty>(
    this HtmlHelper<TModel> htmlHelper, 
    Expression<Func<TModel, TProperty>> expression
)
{
    ...
}
Run Code Online (Sandbox Code Playgroud)

你也可以结帐similar post.