我有以下ajax脚本
$(function () {
$("#btnConfirmParticipants").click(function () {
var jsonArray = [];
$(".form-horizontal").each(function () {
jsonArray.push({ Name: ($(this).find("#Name").val()), Surname: ($(this).find("#Surname").val()), BirthDate: ($(this).find("#BirthDate").val()) });
});
$.ajax({
type: "POST",
url: "/ClientReservations/AddParticipants",
data: JSON.stringify(jsonArray),
dataType: 'application/json; charset=utf-8',
success: function (response) {
},
failure: function (response) {
alert(response.responseText);
},
error: function (response) {
alert(response.responseText);
}
});
});
});
此脚本负责使用List作为参数
在控制器中执行方法[HttpPost]
[Authorize(Roles ="Klient")]
public ActionResult AddParticipants(IList<Participant> participants)
{
return View();
}
模特参与者看起来像这样
public class Participant
{
public Participant()
{
this.Reservation_House_Participant = new HashSet<Reservation_House_Participant>();
}
[Display(Name ="Id:")]
[Required]
public int Id { get; set; }
[Display(Name ="Imię:")]
[Required]
[MinLength(3),MaxLength(15)]
public string Name { get; set; }
[Display(Name ="Nazwisko:")]
[Required]
[MinLength(3),MaxLength(15)]
public string Surname { get; set; }
[Display(Name ="Data urodzenia:")]
[Required]
[DataType(DataType.Date)]
[DisplayFormat(DataFormatString ="{0:dd-MM-yyyy}",ApplyFormatInEditMode =true)]
public DateTime BirthDate { get; set; }
}
当我点击按钮执行ajax脚本时,它会将我重定向到控制器方法,在debbuger中,我看到参数 IList参与者为空?可能是什么原因?
答案 0 :(得分:3)
您的jQuery中有错误,您需要设置contentType
,而不是dataType
属性:
$.ajax({
type: "POST",
url: "/ClientReservations/AddParticipants",
data: JSON.stringify(jsonArray),
contentType: 'application/json; charset=utf-8', //<-- this line
success: function (response) {
},
failure: function (response) {
alert(response.responseText);
},
error: function (response) {
alert(response.responseText);
}
});