3

我正在尝试创建一个 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>
4

1 回答 1

4

代替:

JSON.stringify(person)

做这个:

JSON.stringify({ model: person });

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

于 2012-12-10T17:21:30.157 回答