将列表和字符串数据从ajax传递到mvc 4中的控制器,为列表获得NULL
本文关键字:列表 控制器 NULL 数据 字符串 ajax mvc | 更新日期: 2023-09-27 18:16:12
嗨,我是JavaScript和MVC的新手,我试图将列表和字符串传递给我的控制器。
JavaScript看起来像:
var parms = {
globalList: globalList,
fieldName: fieldName
};
$.ajax({
//contentType: 'application/json; charset=utf-8',
type: "POST",
traditional: true,
url: "/Home/SaveField",
async: false,
data: parms,
dataType: "json",
success: function (data) {
console.log("uspjeh");
},
error: function (errorData) {
console.log("errors");
}
});
});
和控制器看起来像:
public void SaveField(List<Point> globalList, String fieldName)
{
// filedName is correctly passed
// list is null
}
有人能帮我一下吗?点类:
public class Point
{
[Key]
public int PointId { get; set; }
public float GeoDuzina { get; set; }
public float GeoSirina { get; set; }
[ForeignKey("Data")]
public int DataId { get; set; }
public virtual Data Data { get; set; }
}
行不通。如果你稍微调试一下,你会看到你向服务器发布了这样的内容:
globalList:[object Object]
globalList:[object Object]
globalList:[object Object]
它只是一个字符串数组。但总有办法做到你想做的。你可以将数组序列化为json,然后在控制器中反序列化。只需将参数更改为:
var parms = {
globalList: JSON.stringify(globalList),
fieldName: fieldName
};
和行动:
[HttpPost]
public void SaveField(string globalList, string fieldName)
{
var serializer = new JavaScriptSerializer(); //use any serializer you want
var list = serializer.Deserialize<List<Point>>(globalList);
}
或者你可以让param对象看起来像HTML表单:
var parms = {
"globalList[0].GeoDuzina": 51.506760996586294,
"globalList[0].GeoSirina": -0.06106463202740998,
"globalList[1].GeoDuzina": 51.516269286402846,
"globalList[1].GeoSirina": -0.056258113472722464,
"globalList[2].GeoDuzina": 51.50419662363912,
"globalList[2].GeoSirina": -0.044413478462956846,
fieldName: fieldName
};
配合你的动作。
有很多其他方法可以做到这一点。我只展示了其中的两个。有什么对你有好处吗?
顺便说一句。