简体   繁体   English

如何通过AJAX调用将DataSourceRequest和序列化的表单数据发送到MVC控制器

[英]How to send a DataSourceRequest and serialized form data to MVC controller via AJAX call

I am having an issue with posting form data and a DataSourceRequest to my controller method via Ajax. 我在通过Ajax将表单数据和DataSourceRequest发布到我的控制器方法时遇到问题。 I am able to pass each object individually but when I try to pass both objects, my DataSourceRequest is always null. 我可以单独传递每个对象,但是当我尝试传递两个对象时,我的DataSourceRequest始终为null。

Here is my js code: 这是我的js代码:

function submitForm() {

    var grid = $('#denialGrid').data('kendoGrid');

    parameterMap = grid.dataSource.transport.parameterMap;

    var requestObject = parameterMap({
        sort: grid.dataSource.sort(), filter: grid.dataSource.filter(), group: grid.dataSource.group(), page: grid.dataSource.page(),
        pageSize: grid.dataSource.pageSize()
    });

    var formData = $('#BillingForm').serialize();
    $.ajax({
        type: "POST",
        url: '@Url.Action("SaveUpdate", "Home")',
        data: {requestObject,formData}, 
        success: alert(JSON.stringify(requestObject)),

    })
}

And here's my controller method 这是我的控制器方法

[HttpPost]
    public ActionResult SaveUpdate([DataSourceRequest] DataSourceRequest request, UpdateViewModel vm)
    {

        return null;
    }

I've tried: 我试过了:

data: {requestObject,formData},
data: [requestObject,formData],
data: requestObject, formData,
data: (requestObject,formData),
data: {request: requestObject, vm: formData},

Any help would be greatly appreciated 任何帮助将不胜感激

You should include formData inside requestObject, and only pass requestObject 您应该在requestObject中包含formData,并且仅传递requestObject

  var requestObject = parameterMap({ sort: grid.dataSource.sort(), filter: grid.dataSource.filter(), group: grid.dataSource.group(), page: grid.dataSource.page(), pageSize: grid.dataSource.pageSize(), formData: $('#BillingForm').serialize() }); $.ajax({ type: "POST", url: '@Url.Action("SaveUpdate", "Home")', data: requestObject, success: alert(JSON.stringify(requestObject)), }) 

And I think serialize() will only return string. 而且我认为serialize()将仅返回字符串。 You need to convert it to object. 您需要将其转换为对象。 Or you can try this 或者你可以尝试这个

 [HttpPost] public ActionResult SaveUpdate([DataSourceRequest] DataSourceRequest request, string formData) { return null; } 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM