使用MVC3控制器的以下操作:
[HttpPost]
public ActionResult GetAsiguratiSuplimentari(int numarAsiguratiSuplimentari, AcpComplexAsigurat[] oldData)
{
var newData = new List<AcpComplexAsigurat>(oldData);
for(int i = newData.Count; i < numarAsiguratiSuplimentari; i++)
{
newData.Add(new AcpComplexAsigurat());
}
return PartialView("AsiguratiSuplimentari", newData);
}
和js:
$("#NumarAsiguratiSuplimentari").change(function (e) {
var data = { oldData: $("#div-asigurati-suplimentari").find('input').serialize(), numarAsiguratiSuplimentari: $("#NumarAsiguratiSuplimentari").val() };
var postData = JSON.stringify(data);
$.post('@Url.Action("GetAsiguratiSuplimentari")', postData, function (data) {
$("#div-asigurati-suplimentari").html(data);
});
});
我想获取用户选择的select选项并序列化输入表以发送到上述操作:
<h3>Asigurati</h3>
<div class="field half odd">
<label>Numar asigurati suplimentari</label>
<select id="NumarAsiguratiSuplimentari" name="NumarAsiguratiSuplimentari">
@for (int i = 0; i <= 30; i++)
{
<option value="@i" @(Model.Asigurati.Count == i ? "selected" : "")>@i</option>
}
</select>
</div>
<div class="field full" id="div-asigurati-suplimentari">
@if (Model.Asigurati.Count > 0)
{
<table id="Asigurati">
<thead>
<tr>
<th>CNP</th>
<th>Nume</th>
<th>Prenume</th>
<th>Data nasterii</th>
</tr>
</thead>
<tbody>
@foreach (var item in Model.Asigurati)
{
<tr>
<td style="padding: 3px;">@Html.TextBoxFor(x => Model.Asigurati[Model.Asigurati.IndexOf(item)].Cnp, new { maxlength = 13 })</td>
<td style="padding: 3px;">@Html.TextBoxFor(x => Model.Asigurati[Model.Asigurati.IndexOf(item)].Nume)</td>
<td style="padding: 3px;">@Html.TextBoxFor(x => Model.Asigurati[Model.Asigurati.IndexOf(item)].Prenume)</td>
<td style="padding: 3px;">@Html.TextBoxFor(x => Model.Asigurati[Model.Asigurati.IndexOf(item)].DataNastere)</td>
</tr>
}
</tbody>
</table>
}
</div>
在单轨列车中,我不得不用{JsonBinder]属性修饰输入参数,但在MVC3中我不知道如何继续。
它基本上给了我以下错误:
参数字典包含参数的空条目 'numarAsiguratiSuplimentari'的非可空类型'System.Int32'代表 方法'System.Web.Mvc.ActionResult GetAsiguratiSuplimentari(Int32, BrokerPlatform.Services.AcpComplex.AcpComplexAsigurat [])'in 'BrokerPlatform.Areas.AcpComplex.Controllers.CarpaticaController'。一个 可选参数必须是引用类型,可空类型或be 声明为可选参数。参数名称:参数
以下是它发送的JSON:
{ “numarAsiguratiSuplimentari”: “2”, “OLDDATA”: “”}
答案 0 :(得分:0)
参数不一致。
public ActionResult GetAsiguratiSuplimentari(int numarAsiguratiSuplimentari?, AcpComplexAsigurat[] oldData)
int? numarAsiguratiSuplimentari
可以为?
或
$.post('@Url.Action("GetAsiguratiSuplimentari")', {numarAsiguratiSuplimentari:number,AcpComplexAsigurat:list}, function (data) {
... {numarAsiguratiSuplimentari:number,AcpComplexAsigurat:list}
...
您可以解析字符串并获取json,然后转换为模型。
我的样本;
[HttpPost()]
public ActionResult GetAsiguratiSuplimentari(string model)
{
List<myModel> myModel = JsonConvert.DeserializeObject<List<muModel>>(model);
}
答案 1 :(得分:0)
我现在没有MVC 3,但这对MVC 4(使用Fiddler)工作正常。您可以尝试一些事项:
dataType: "json"
调用中明确设置$.post
,jQuery可能无法猜到它。string
而不是int
,MVC 3中的绑定可能无法自动执行。如果其中一项有效,请告诉我,以便删除错误的选项。