假设我有一个包含表单的弹出窗口。我必须有一个处理表单的控制器,根据结果,这个控制器返回 JSON(如果一切顺利,并且弹出窗口可以通过 javascript 关闭)或 HTML(如果表单数据无效并且必须替换表单)带有新的 html - 带有验证错误消息)。所以我找到了这样一个解决方案:那就是形式:
<form id="message" ...>
...
</form>
我有这个表单的 jquery 处理程序:
$(document).on("submit", "form#message", function (evt) {
evt.preventDefault();
$.ajax({
type: this.method,
url: this.action,
data: $(this).serialize(),
success: function (result) {
if ($.isPlainObject(result)) {
// this is JSON
// close the pop-up window
} else {
// this is HTML
$("form#message").html(result);
}
}
});
});
控制器:
[HttpPost]
public ActionResult UpdateMessage(MessageModel model)
{
...
if (.. is valided ..)
return Json(new { success = "OK" });
else
return View(model);
}
问题 - 对于此类任务是否有更优雅的解决方案?