无法读取控制器中的$ .ajax数据

时间:2012-12-10 17:18:46

标签: jquery ajax asp.net-mvc json

我正在尝试创建一个jQuery .ajax程序,其中用户单击视图中的按钮,触发$ .ajax,然后发送名称到控制器,控制器在名称前面添加hello并发回json响应。

我设法从控制器接收JSON响应,但未能在控制器中读取发布数据name

这是我的代码:

控制器类

    public JsonResult processJsonRequest(PersonModel model)
    {       
        string returnString = "Hello , receive JSON data" + model.Name;
        return Json(returnString, JsonRequestBehavior.AllowGet);
    }

模型类

public class PersonModel
{
    public string Name { get; set; }
}

视图

@{
ViewBag.Title = "Index";}

 @Scripts.Render("~/bundles/jquery")

 @using (Html.BeginForm())
   {
      <input type="button" id="b1" value ="Press Me" />  
   }

 <script type="text/javascript">

   $(document).ready(function () {

    $("#b1").click(function () {

        var person = { Name: 'khurram' };

        $.ajax({
            type: "POST",

            url: "/JSON_Ajax_03/processJsonRequest",
            data: JSON.stringify(person),
            dataType: "json",
            contentType: "application/json; charset=utf-8",
            success: function (response) {
                alert(response);
            }
        });
    });
});

</script>

1 个答案:

答案 0 :(得分:4)

而不是:

JSON.stringify(person)

这样做:

JSON.stringify({ model: person });

问题是您没有正确命名模型参数。