14

我正在尝试使用 MVC 4 中的 Ajax.BeginForm 辅助方法将表单从同步转换为异步。

在我看来,我有:

   @{
        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>
4

3 回答 3

28

有什么我想念的吗?

也许你错过了不显眼的 ajax 脚本:

<script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")" type="text/javascript"></script>
于 2012-01-30T15:37:54.543 回答
0

如果我理解正确,您正在尝试将数据发布到控制器,成功后您需要转到主页??如果不是,你能澄清一下。这样会尽力帮助你

if (ModelState.IsValid)
    {
        _repository.Save(user);
        TempData["message"] = String.Format("{0} has been saved.", user.Username);
        return RedirectToAction("yourActionToRedirect");  // after succesfull it will go to the index view
    }
于 2012-01-30T15:32:49.887 回答
0

我遇到了同样的问题......我已经使用 nuget 包控制台更新了所有 js 文件。

只是我的 2 美分,但在撰写本文时,jquery.unobtrusive.ajax 文件确实包含对已弃用的 jquery 函数“.live”的调用(=> 它已从 jquery 1.9+ 版本中删除)jquery live

我认为您必须使用.on更改 4 次,现在它工作正常;-)

于 2013-01-31T11:58:22.313 回答