Подтвердить что ты не робот

ValidationSummary и ValidationMessageFor с пользовательским CSS показано, когда нет ошибок

Как только я применил пользовательский 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;
}
4b9b3361

Ответ 1

Для них уже построены типы 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;
}

в файле css по умолчанию для проектов MVC3. Они отображаются соответствующим образом на основе, если ModelState имеет какие-либо ошибки для Property, указанных или вообще для ValidationSummary. Если в ModelState нет ошибок, тогда display:none; из .field-validation-valid скроет ошибки.

Ответ 2

Мы не ставим класс обязательных для наших ValidationMessagesFor helpers

<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>