MVC3无法解析JSON

时间:2013-06-26 08:53:50

标签: c# json asp.net-mvc-3 jquery

使用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”: “”}

2 个答案:

答案 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中的绑定可能无法自动执行。

如果其中一项有效,请告诉我,以便删除错误的选项。