2017-05-27 127 views
1

我想从视图传递一个对象到控制器使用Ajax。但我在控制器中的对象内获得空值。我的代码如下..你能帮我解决这个问题Ajax调用返回空值的对象

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script> 
function Save() { 
    // var Trip={output}; 
    debugger; 
    var stop; 
    var table = $('#scheduletable').DataTable(); 
    var rows = $('#scheduletable tr'); 
    var StopNames = ''; 
    var TripNumbers = ''; 
    var TripDetails = ''; 
    StopNames += table.column(0).data().toArray().join("&"); 
    for (var i = 1; i < rows[0].cells.length; i++) { 
     TripNumbers += rows[0].cells[i].innerText + '&'; 
     TripDetails += table.column(i).data().toArray().join("&"); 
    } 
    debugger; 
    TripNumbers = TripNumbers.replace(/(\r\n|\n|\r)/gm, ""); 
    var output = { 
     'StopNames': StopNames, 
     'TripNumbers': TripNumbers, 
     'TripDetails': TripDetails 
    }; 
    $.ajax({ 
     type: "POST", 
     url: "/ScheduleManagement/ScheduleManagement/SaveSchedules", 
     // contentType: 'application/json;', 
     dataType: "json", 
     data: JSON.stringify(output), 
     success: function (values) { 
     }, 
     error: function (err) { 
      console.log(err); 
     } 
    }); 
} 

我使用控制器下面的代码

[HttpPost] 
public JsonResult SaveSchedules(TripsToSave output) 
{ 
    // dynamic item = output; 
    int serviceId = Convert.ToInt32(Session["ServiceGroupId"]); 
    // int status= _scheduleManagementBL.SaveMasterSchedule(output); 
    return Json("1", JsonRequestBehavior.AllowGet); 
    // return RedirectToAction("DisplayHttpError", "Error"); 
} 

实体。我正在使用此代码

public class TripsToSave 
{ 
    public string StopNames { get; set; } 
    public string TripNumbers { get; set; } 
    public string TripDetails { get; set; } 
} 
+0

你通过你直接StopNames,TripNumbers得到PARAMS Ajax请求数据的方式, TripDetails不通过输出。 –

+0

只是'数据:输出,'(或者如果你真的把它串起来,那么你需要'contentType:'application/json;'') –

回答

1

那么你可以试试这个

var output = { 
     StopNames: 'StopNames', // change the value with string 
     TripNumbers: 'TripNumbers', // change the value with string 
     TripDetails: 'TripDetails' // change the value with string 
    }; 

$.ajax({ 
    type: "POST", 
    url: "/ScheduleManagement/ScheduleManagement/SaveSchedules", 
    contentType: 'application/json; charset=utf-8', 
    dataType: "json", 
    data: JSON.stringify(output), 
    success: function (values) { 
    }, 
    error: function (err) { 
     console.log(err); 
    } 
}); 

数据类型: 'JSON',

其平均收益率从服务器的数据的类型应该是JSON

的contentType: “应用程序/ JSON;字符集= UTF-8' ,

它的平均数据类型前应JSON将其发送给服务器,你的情况,你需要将数据转换成JSON stringfy ..

注:

弃用声明:从jQuery 3.0开始,将删除jqXHR.success(),jqXHR.error()和jqXHR.complete()回调。您可以使用jqXHR.done(),jqXHR.fail(),和jqXHR.always(),而不是更多产品详情请登陆 - 参观

+0

感谢您的帮助..当我根据您的建议更改我的代码时它工作正常。 – vIDHU

+0

你可以接受它回答:)很高兴帮助你。 –

0

您不需要将输出数据串联起来,传递就是这样。

 var StopNames = 'ss'; 
     var TripNumbers = 'ss'; 
     var TripDetails = 'cc'; 

      var output = { 
      'StopNames': StopNames, 
      'TripNumbers': TripNumbers, 
      'TripDetails': TripDetails 
     }; 

     $.ajax({ 
      type: "POST", 
      url: "/abc/SaveSchedules", 

      dataType: "json", 
      data: output, 
      success: function (values) { 
      }, 
      error: function (err) { 
       console.log(err); 
      } 
     });