ValidationSummary和ValidationMessageFor在没有错误时显示自定义CSS

时间:2011-08-01 14:06:47

标签: css asp.net-mvc-3 validation

一旦我将自定义CSS应用于ValidationSummary和ValidationMessageFor,即使没有错误,它也会显示在页面上。 CSS确实有图像。

如果没有错误,如何隐藏摘要和错误?

@Html.ValidationSummary("", new { @class = "required" })
@Html.ValidationMessageFor(m => m.UserName, null, new { @class = "required" })


.required {
    background-image: url(/images/required.jpg);
    background-repeat: no-repeat;
    height: 33px;
    width: 386px;
    font-family: "Trebuchet MS", Arial, Helvetica, sans-serif;
    font-size: 13px;
    font-weight: bold;
    color: #1eb4ec;
    padding-top: 16px;
    padding-left: 54px;
    margin-left: 30px;
}

2 个答案:

答案 0 :(得分:27)

这些已经内置了css类型:

/* Styles for validation helpers
-----------------------------------------------------------*/
.field-validation-error {
    color: #ff0000;
}

.field-validation-valid {
    display: none;
}

.input-validation-error {
    border: 1px solid #ff0000;
    background-color: #ffeeee;
}

.validation-summary-errors {
    font-weight: bold;
    color: #ff0000;
}

.validation-summary-valid {
    display: none;
}

在MVC3项目的默认css文件中。这些是根据ModelState是否有Property指定的任何错误或ValidationSummary的任何错误而适当显示的。如果ModelState中没有错误,则display:none;中的.field-validation-valid将隐藏错误。

答案 1 :(得分:-3)

我们没有在ValidationMessagesFor帮助

上放置一类必需的
<li>
                    <label for="NameFirst">First Name <span>* Required</span></label>
                    <span class="field-container">
                        @Html.TextBoxFor(m => m.FirstName, new { required = "required", data_type="name" })
                        @Html.ValidationMessageFor(m => m.FirstName)
                    </span>
                </li>