1

我在使用 AJAX POST 时遇到问题。我正在定义我希望在哪里发布 AJAX 调用,但它在其他地方发布。请帮忙。

我正在使用 MVC Telerik Grid。如果您不熟悉它,它可能并不重要。我正在关注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()方法没有:(参见http://i.stack.imgur.com/GPCS6.png

在这张图片中,第一个帖子 url 对应于传递给我的Select()方法的值。Update()第二个帖子网址与我的方法不对应。

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

4

1 回答 1

0

所以事实证明我所做的并没有错。MVC 项目不知何故变得一团糟。

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

于 2013-05-28T17:09:16.293 回答