我有一个基本的 HTML,它使用 jquery ajax 调用来调用 WebAPI 函数。 HTML 发送一个对象数组,这些对象应该映射到我作为列表接收的函数参数。如果我删除数组并仅发送 1 个对象,并从函数中删除列表,那么我的代码将正常工作,并且对象将成功传递给参数。
JavaScript代码如下
function Call_Service () {
var input =
{
STATUS: "MY New Status",
CATEGORY: "My Value"
};
var input2 =
{
STATUS: "MY New Status2",
CATEGORY: "My Value2"
};
var input_array = new Array();
input_array[0] = input;
input_array[1] = input2;
$.ajax({
type: "POST",
url: "http://localhost:34989/api/TMSPortal/objectPOC",
data: input_array,
success: function (response) {
alert(response);
}
});
}
C# WebAPI如下
public Int64 objectPOC(List<TMS_STATUS> _Status)
{
Int64 retValu = 0;
for (int i = 0; i < _Status.Count; i++)
{
retValu++;
}
return retValu;
}
最佳答案
当我知道 Web-API 目前不允许超过 1 个复杂参数时,因此我通过以下解决方法完成了工作。如果有人有更好的解决方案,请告诉我:
更改了 Web-API 函数以接收 JObject,然后从中提取我的复杂对象。 Web-API 函数如下所示:
public Int64 objectPOC(JObject jsonWrapper)
{
dynamic jsonValues = jsonWrapper;
JArray jsonInput = jsonValues.input;
JArray jsonInput2 = jsonValues.input2;
List<TMS_STATUS> _Status = jsonInput.ToObject<List<TMS_STATUS>>();
List<TMS_STATUS> _Status2 = jsonInput2.ToObject<List<TMS_STATUS>>();
Int64 retValu = 0;
for (int i = 0; i < _Status.Count; i++)
{
retValu++;
}
return retValu;
}
Ajax调用如下:
function Call_Service () {
var input =
{
STATUS: "MY New Status",
CATEGORY: "My Value"
};
var input2 =
{
STATUS: "MY New Status2",
CATEGORY: "My Value2"
};
var input_array = new Array();
input_array[0] = input;
input_array[1] = input2;
alert(input_array[0].STATUS);
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "http://localhost:34989/api/TMSPortal/objectPOC",
dataType: "json",
data: JSON.stringify({
input: input_array,
input2: input_array
}),
success: function (response) {
alert(response);
}
});
}
关于jquery - 如何将对象数组传递给 webAPI 列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15071120/