Я пытаюсь преобразовать форму из синхронной в асинхронную, используя вспомогательный метод Ajax.BeginForm в MVC 4.
На мой взгляд, у меня есть:
@{
ViewBag.Title = "Users > Edit";
var options = new AjaxOptions()
{
Url = Url.Action("Edit", "User"),
LoadingElementId = "saving",
LoadingElementDuration = 2000,
Confirm = "Are you sure you want to save this User?"
};
}
<div id="saving" style="display:none; color:Red; font-weight: bold">
<p>Saving...</p>
</div>
@using (Ajax.BeginForm(options))
{
@Html.ValidationSummary(true)
<fieldset>
.... FIELDS ...
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
}
Когда нажата кнопка отправки, выполняется полный постбэк. Мой метод действия выглядит так:
[HttpPost]
public ActionResult Edit(User user)
{
if (ModelState.IsValid)
{
_repository.Save(user);
TempData["message"] = String.Format("{0} has been saved.", user.Username);
}
return View(user);
}
Есть ли что-то, что я пропускаю? У текущего выпуска MVC 4 есть несколько проблем?
В моем файле Web.Config для ClientValidationEnabled и UnobtrusiveJavaScriptEnabled установлено значение true.
Я также указал это в моем _Layout.cshtml:
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>