AJAX调用错误的URL。是什么赋予了?

时间:2013-05-25 20:01:14

标签: ajax asp.net-mvc-3 post telerik

我遇到了一个AJAX POST问题。我正在定义我希望发布AJAX调用的位置,但是它在其他地方发布。请帮忙。

我正在使用MVC Telerik Grid。如果你不熟悉它,probalby并不重要。我正在关注http://demos.telerik.com/aspnet-mvc/razor/grid/editingbatch

的例子

从该示例中,此网格拼图的重要部分包括:

.Editable(editing => editing.Mode(GridEditMode.InCell))

同样从该示例中,定义AJAX调用的url:

.DataBinding(dataBinding => dataBinding.Ajax()
        .Select("_SelectContactsBatchEditing", "Ajax", new {FirstName = @ViewData["FirstName"], LastName = @ViewData["LastName"]})
        .Update("_SaveContactsBatchEditing", "Ajax", new {FirstName = @ViewData["FirstName"], LastName = @ViewData["LastName"]})
    )

对于Select()Update()方法,第一个参数是Action,第二个参数是Controller。我有第三个可选参数,其中包含要在帖子中发回的其他数据。

我的网格是主/细节。我已经拿出了细节部分,我仍然有问题。我给你我整个网格。现在请让我们关注主要部分。

@(Html.Telerik().Grid<ContactView>()
    .Name("ContactsGrid")
    .Columns(columns =>
    {
        columns.Bound<int>(c => c.Id).Width(65).ReadOnly();
        columns.Bound<string>(c => c.FirstName).Width(100);
        columns.Bound<string>(c => c.LastName).Width(100);
        columns.Bound<string>(c => c.Phone).Width(120);
        columns.Bound<string>(c => c.Street).Width(200);
        columns.Bound<string>(c => c.City).Width(100);
        columns.Bound<string>(c => c.Province).Width(50).Title("Prov");
        columns.Bound<string>(c => c.PostalCode).Width(80).Title("PC");
        columns.Bound<string>(c => c.Email).Width(100);
        columns.Bound<bool>(c => c.OkToContact).Width(40).Title("Ok")
            .ClientTemplate("<input type='checkbox' disabled='disabled' name='OkToContact' <#=OkToContact? checked='checked' : '' #> />");
        columns.Command(commands =>
        {
            commands.Delete();
        }).Width(100);
    })
    .DetailView(details => details.ClientTemplate(
            Html.Telerik().Grid<DonationView>()
                .Name("Donations_<#= Id #>")
                .Resizable(resizing => resizing.Columns(true))
            .Editable(editing => editing.Mode(GridEditMode.InCell).DefaultDataItem(new DonationView(){Description = "Internal Cause"}))
                .DataKeys(d => d.Add<int>(a => a.Id).RouteKey("Id"))
                .Columns(columns =>
                {
                    columns.Bound(o => o.Id).Width(65).ReadOnly();
                    columns.Bound(o => o.Description).Width(400);
                    columns.Bound(o => o.Amount).Width(80);
                    columns.Bound(o => o.Date).Format("{0:d}");
                })
                /*.ClientEvents(events => events.OnRowDataBound("cause_onRowDataBound"))*/
                .DataBinding(dataBinding => dataBinding.Ajax()
                    .Select("_SelectDonationsHierarchyBatchEditing", "Ajax", new { ContactID = "<#= Id #>" })
                    .Update("_SaveDonationsHierarchyBatchEditing", "Ajax", new {ContactID = "<#= Id #>"})
                )
                .Sortable()
                .ToolBar(commands => {
                    commands.Insert();
                    commands.SubmitChanges();
                })
                /*.Filterable()*/
                .ToHtmlString()
    ))
    .DataBinding(dataBinding => dataBinding.Ajax()
        .Select("_SelectContactsBatchEditing", "Ajax", new {FirstName = @ViewData["FirstName"], LastName = @ViewData["LastName"]})
        .Update("_SaveContactsBatchEditing", "Ajax", new {FirstName = @ViewData["FirstName"], LastName = @ViewData["LastName"]})
    )
    .Resizable(resizing => resizing.Columns(true))
    //.Pageable(paging => paging.PageSize(25))
    .Editable(editing => editing.Mode(GridEditMode.InCell))
    .DataKeys(d => d.Add<int>(a => a.Id).RouteKey("Id"))
    .Scrollable(scrolling => scrolling.Height(500))
    .ToolBar(commands => {
        commands.Insert();
        commands.SubmitChanges();
    })
    //.HtmlAttributes(new { style = "width: 1200px" } ) 
    .Sortable()
      )

我的Select()方法调用正确,但我的Update()方法没有。它只是发布到网格所在的同一页面。我有这个工作,但没有费心去检查(愚蠢),并在几天后打破它。没有多少Ctrl + Z帮助了我。

这是我的Ajax控制器中的操作。细节已删除,因为它们无关紧要。该方法不会被调用。

 [GridAction]
        [AcceptVerbs(HttpVerbs.Post)]
        public ActionResult _SaveContactsBatchEditing([Bind(Prefix = "inserted")]IEnumerable<ContactView> insertedContacts,
            [Bind(Prefix = "updated")]IEnumerable<ContactView> updatedContacts,
            [Bind(Prefix = "deleted")]IEnumerable<ContactView> deletedContacts, string FirstName, string LastName)
        {
            ISession session = SessionManager.OpenSession();
            ContactProvider cp = new ContactProvider(session);
            if (insertedContacts != null)
            {
                //stuff
            }
            if (updatedContacts != null)
            {
                //stuff
            }
            if (deletedContacts != null)
            {
                //stuff
            }

            IList<ContactView> Contacts = new List<ContactView>();
            ContactViewProvider Provider = new ContactViewProvider(SessionManager.OpenSession());
            Contacts = Provider.GetContactsByName(FirstName, LastName);
            //return View(new GridModel(Contacts));
            return new LargeJsonResult
            {
                MaxJsonLength = int.MaxValue,
                JsonRequestBehavior = System.Web.Mvc.JsonRequestBehavior.AllowGet,
                Data = new GridModel<ContactView>
                {
                    Data = Contacts
                }
            };
        }

当我单击网格工具栏中的“保存”按钮时,我可以使用firebug看到Select()方法进行正确的AJAX调用,但Update()方法没有:(参见{{3} })

在此图片中,第一个帖子网址与传递到我的Select()方法的值相对应。第二个帖子网址与我的Update()方法不符。

这里发生了什么?提前致谢

1 个答案:

答案 0 :(得分:0)

事实证明,我所做的事情并没有错。 MVC项目莫名其妙地搞砸了。

我创建了一个一次性项目试图重现这个问题,但我不能 - 一次性工作。所以我在我的解决方案中删除了MVC项目并将这些部分逐个复制到新项目中,果然,它确实有效。我不知道它首先是如何变得混乱,但至少问题得到纠正。对于任何有同样问题的人,我建议你试试这个!