Ответ 1
Вы можете сделать это с помощью этого одного лайнера:
@Html.Raw(HttpUtility.HtmlDecode(Html.ValidationMessageFor(m => m.Property).ToHtmlString()))
Я тестирую список вещей для null. Каждый раз, когда я нахожу его, я сохраняю его в массиве, чтобы реализовать его в validationmessage.
Выход, который я хочу, выглядит следующим образом:
Поле 1 требуется
Поле 4 требуется
и т.д...
Но я не могу начать новую строку.
Теперь это выглядит так:
Поле 1 требуется Поле 4 требуется
Кто-нибудь знает, как это достичь?
EDIT:
контроллер:
IDictionary<int, String> emptyFields = new Dictionary<int, String>();
foreach (Something thing in AnotherThing.Collection)
{
if (thing.Property == null)
emptyFields.add(thing.Index, thing.Name);
}
if (emptyFields.Any())
throw new CustomException() { EmptyFields = emptyFields };
Это исключение обрабатывается здесь:
catch (CustomException ex)
{
ModelState.AddModelError("file", ex.GetExceptionString());
return View("theView");
}
CustomException:
public class CustomException: Exception
{
public IDictionary<int,String> EmptyFields { get; set; }
public override String Label { get { return "someLabel"; } }
public override String GetExceptionString()
{
String msg = "";
foreach (KeyValuePair<int,String> elem in EmptyFields)
{
msg += "row: " + (elem.Key + 1).ToString() + " column: " + elem.Value + "<br/>";
}
return msg;
}
}
Вид:
<span style="color: #FF0000">@Html.Raw(Html.ValidationMessage("file").ToString())</span>
Вы можете сделать это с помощью этого одного лайнера:
@Html.Raw(HttpUtility.HtmlDecode(Html.ValidationMessageFor(m => m.Property).ToHtmlString()))
Для этого вам нужно написать собственный помощник. Встроенный помощник ValidationMessageFor
автоматически HTML кодирует значение. Вот пример:
public static class ValidationMessageExtensions
{
public static IHtmlString MyValidationMessageFor<TModel, TProperty>(
this HtmlHelper<TModel> htmlHelper,
Expression<Func<TModel, TProperty>> ex
)
{
var htmlAttributes = new RouteValueDictionary();
string validationMessage = null;
var expression = ExpressionHelper.GetExpressionText(ex);
var modelName = htmlHelper.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldName(expression);
var formContext = htmlHelper.ViewContext.ClientValidationEnabled ? htmlHelper.ViewContext.FormContext : null;
if (!htmlHelper.ViewData.ModelState.ContainsKey(modelName) && formContext == null)
{
return null;
}
var modelState = htmlHelper.ViewData.ModelState[modelName];
var modelErrors = (modelState == null) ? null : modelState.Errors;
var modelError = (((modelErrors == null) || (modelErrors.Count == 0))
? null
: modelErrors.FirstOrDefault(m => !String.IsNullOrEmpty(m.ErrorMessage)) ?? modelErrors[0]);
if (modelError == null && formContext == null)
{
return null;
}
var builder = new TagBuilder("span");
builder.MergeAttributes(htmlAttributes);
builder.AddCssClass((modelError != null) ? HtmlHelper.ValidationMessageCssClassName : HtmlHelper.ValidationMessageValidCssClassName);
if (!String.IsNullOrEmpty(validationMessage))
{
builder.InnerHtml = validationMessage;
}
else if (modelError != null)
{
builder.InnerHtml = GetUserErrorMessageOrDefault(htmlHelper.ViewContext.HttpContext, modelError, modelState);
}
if (formContext != null)
{
bool replaceValidationMessageContents = String.IsNullOrEmpty(validationMessage);
builder.MergeAttribute("data-valmsg-for", modelName);
builder.MergeAttribute("data-valmsg-replace", replaceValidationMessageContents.ToString().ToLowerInvariant());
}
return new HtmlString(builder.ToString(TagRenderMode.Normal));
}
private static string GetUserErrorMessageOrDefault(HttpContextBase httpContext, ModelError error, ModelState modelState)
{
if (!String.IsNullOrEmpty(error.ErrorMessage))
{
return error.ErrorMessage;
}
if (modelState == null)
{
return null;
}
var attemptedValue = (modelState.Value != null) ? modelState.Value.AttemptedValue : null;
return string.Format(CultureInfo.CurrentCulture, "Value '{0}' not valid for property", attemptedValue);
}
}
а затем:
public class MyViewModel
{
[Required(ErrorMessage = "Error Line1<br/>Error Line2")]
public string SomeProperty { get; set; }
}
и в представлении:
@model MyViewModel
@using (Html.BeginForm())
{
@Html.EditorFor(x => x.SomeProperty)
@Html.MyValidationMessageFor(x => x.SomeProperty)
<button type="submit">OK</button>
}
И если вы хотите отобразить сообщение об ошибке в ValidationSummary, вы также можете написать пользовательский помощник, который не будет кодировать HTML-сообщение об ошибке, как я показал в this post
.
попробуйте этот
добавить
тег после каждого сообщения об ошибке и использовать метод Html.Raw() для отображения вашего контента. Html.Raw расшифровывает HtmlContent.
you message like
Field 1 is required <br/>Field 4 is required<br/>
In View
Html.Raw("Yore Error Message")
Вы показываете их в сводке проверки? Я не думаю, что он поддерживает html для разрывов строк и т.д. Я бы создал пользовательский html-помощник на основе сводки проверки, отображающей html.
То же самое относится к validationmessage, поэтому, вероятно, нужно создать собственный помощник для
то, что я делаю, связывает их в div
<div class="Errors">
@Html.ValidationMessageFor(m => m.Name)<br/>
@Html.ValidationMessageFor(m => m.LName)<br />
</div>
затем создайте класс
.Errors {
color: red;
font-size: 10px;
font-weight: bold;
}
но если вы хотите сделать многострочную ошибку, то, о чем упомянул Лейнель, причина в том, что некоторые из них не видят ошибки с длинными формами, и они просто начнут звонить нам.. ^^,
В случае, если кто-то его ищет, вот как это сделать для сводки валидации:
@Html.Raw(HttpUtility.HtmlDecode(Html.ValidationSummary(true).ToHtmlString()))