我有以下工作代码:
类(声明的对象)
public class saveRow
{
public int proId { get; set; }
public string proName{get;set;}
}
控制器:
[HttpPost]
public virtual JsonResult SaveRow(saveRow input)
{ /* CODE HERE */}
JavaScript对象(已发送)
var test = {"proId" : 1, "proName" : "Test"}
JavaScript Ajax调用
$.ajax({
type: "POST",
url: "URL",
dataType: "json",
data: test,
traditional: true,
success: function (data, status, request) {
if (data.Error != undefined) {
alert("System Error: " + data.Error);
$(row).find('*').attr('disabled', false);
return;
}
},
error: function (request, status, error) {
console.log("ERROR");
}
});
现在,当我想一次发送行列表而不是一次发送行列表时,便出现了问题,所以我做了以下工作:
为了测试我拿了相同的对象并完成了
var test2 = []; test2.push(test); test2.push(test);
现在该对象看起来像:
[{"proId" : 1, "proName" : "Test"},{"proId" : 1, "proName" : "Test"}]
我的控制器现在看起来像:
[HttpPost]
public virtual JsonResult SaveRow(List<saveRow> input)
{ /* CODE HERE */}
IEnumberable
在将对象列表作为JSON发送时也尝试过,变量输入始终为null。
但是每次我通过控制器参数“输入”发送此列表时,始终为null。
为什么是这样?
解决了-
public virtual JsonResult SaveRow(saveRow[] input)
并添加了内容类型!使用JSON.stringify!
尝试这种方式:
JS:
var data = { "input": test2 };
$.ajax({
type: "POST",
url: "URL",
dataType: "json",
contentType:"application/json; charset=utf-8", //<--Set content Type
data: JSON.stringify(data), //Set data
success: function (data, status, request) {
if (data.Error != undefined) {
alert("System Error: " + data.Error);
$(row).find('*').attr('disabled', false);
return;
}
},
error: function (request, status, error) {
console.log("ERROR");
}
});
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句