Ajax调用是第二次提交时双重发布表单

Chr*_*Run 5 forms ajax asp.net-mvc

嗨,大家好我有问题,我不明白为什么会发生这种情况.

出于某种原因,我的第二次提交时,我的ajax调用是双重发布.

我有一个包含这个的视图:

 @using (Ajax.BeginForm("Create", "BasketPage", new AjaxOptions
{
    InsertionMode = InsertionMode.Replace,
    UpdateTargetId = "myDiv",

}))
    {
        <textarea id="comment" name="comment"> </textarea> <br />
        <input type="submit" class="btn btn-blue" value="Comment" />
    }
Run Code Online (Sandbox Code Playgroud)

调用的BasketPage控制器操作如下所示:

public PartialViewResult Create(BasketPage currentPage, string comment)
        {          
                Comment newComment = new Comment()
                {
                    Username = User.Identity.Name,
                    Text = HttpUtility.HtmlEncode(comment),
                    PageID = currentPage.PageLink.ID
                };

                commentRepository.Save(newComment);

                var model = new BasketListModel(currentPage)
                                {
                                    CommentsList = commentRepository.GetComments(currentPage.PageLink)
                                };

                return PartialView("_Comment", model);
        }
Run Code Online (Sandbox Code Playgroud)

问题场景:

  1. 我输入一个值,提交表格.一切都按预期工作.
  2. 我再次(因此第二次)输入一个值,提交表格.现在调用Save方法两次 - 这导致该值在DB中保存两次,创建两个具有相同值的行.

如果我用常规的@ Html.BeginForm替换Ajax.beginform,则只调用一次Save方法.

我错过了什么?

Luk*_*uke 6

这可能是因为你将不引人注目的JavaScript库包含在页面中两次.

检查并删除捆绑包配置或包含的<script>标签中的任何重复项.