我使用ASP.NET-MVC。我尝试在ajax中发布一个数组,但我不知道如何在我的控制器中获取它。这是我的代码:
的Ajax
var lines = new Array();
lines.push("ABC");
lines.push("DEF");
lines.push("GHI");
$.ajax(
{
url: 'MyController/MyAction/',
type: 'POST',
data: { 'lines': lines },
dataType: 'json',
async: false,
success: function (data) {
console.log(data);
}
});
myController的
public JsonResult MyAction(string[] lines)
{
Console.WriteLine(lines); // Display nothing
return Json(new { data = 0 });
}
为什么我看不到我的台词?如何正确发布此数组并在MyAction中使用它?
答案 0 :(得分:15)
设置contentType: "application/json"
选项和JSON.stringify
参数:
var lines = new Array();
lines.push("ABC");
lines.push("DEF");
lines.push("GHI");
$.ajax(
{
url: 'MyController/MyAction/',
type: 'POST',
data: JSON.stringify({ 'lines': lines }),
dataType: 'json',
contentType: 'application/json',
async: false,
success: function (data) {
console.log(data);
}
});
如果在您的商业案例中有意义,您还可以设置您获得的对象类型。例如:
public JsonResult MyAction(string[] lines)
{
Console.WriteLine(lines); // Display nothing
return Json(new { data = 0 });
}
并且,对于您发送的内容更实用:
public class MyModel {
string[] lines;
}
最后:
public JsonResult MyAction(MyModel request)
{
Console.WriteLine(string.Join(", ", request.lines)); // Display nothing
return Json(new { data = 0 });
}
答案 1 :(得分:-1)
首先,尝试改变:
data: { 'lines': lines }
到
data: { lines: lines },
如果没用,请尝试使用json.stringify(lines)