一旦我将自定义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;
}
答案 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>