我创建了一个帮助我显示jQuery模式对话框的HtmlHelper:我在控制器的TempData中设置了一条消息,如果消息不为null,帮助程序会在回发后编写一个jquery + html代码来弹出窗口。 但我需要将验证结果显示为一条消息(ValidationSummary显示相同的消息),我不知道如何实现这一点。有人能帮我吗?我是以正确的方式做到的吗?
我的helper.cs:
[...]
public static string ModalDialogNotifier(this HtmlHelper helper)
{
string message = "";
if (helper.ViewContext.TempData["message"] != null)
message = helper.ViewContext.TempData["message"].ToString();
if (!String.IsNullOrEmpty(message))
{
StringBuilder sb = new StringBuilder();
sb.AppendLine("<script>$(document).ready(function() {$.blockUI({ message: $('#mdiag')});$('#mdiagok').click(function() {$.unblockUI();return false;});})</script>");
sb.AppendFormat("<div id='mdiag'>{0}<input type='button' id='mdiagok' value='Ok' /></div>", message);
return sb.ToString();
}
return string.Empty;
}
[...]
我的控制器:
[HttpPost]
[Authorize(Roles = "Admin")]
public ActionResult Create(CreateUserModel Model)
{
if (!ModelState.IsValid)
{
this.TempData["message"] = "Model is not valid";
}
else
{
[...]
}
return View(Model);
}
我的观点:
[...]<%= Html.ModalDialogNotifier()%>[...]
答案 0 :(得分:3)
你可以这样做:
StringBuilder sb = new StringBuilder();
foreach (ModelState state in ModelState.Values)
foreach (ModelError error in state.Errors)
sb.AppendFormat("<div>{0}</div>", error.ErrorMessage);