开发者

Response from $.getJSON returns null

开发者 https://www.devze.com 2023-02-04 18:45 出处:网络
I want to call a server side method using Jquery getJSON with .NET 3.5, MVC2 and JQuery1.4.1. I\'ve followed some online tutorials, but cannot get the serverside method to return anything other than

I want to call a server side method using Jquery getJSON with .NET 3.5, MVC2 and JQuery1.4.1.

I've followed some online tutorials, but cannot get the serverside method to return anything other than null. All 3 alerts are fired in the JS below, and I can hit a break point on my server side method (also below). As I'm starting out, I've included all the client side code just in case I have done something stupid. Any idea what I am doing wrong - I've spent ages trying to get a value back from the server. Many thanks.

My client code is: (Each line is missing the beginning <)

<@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.M开发者_StackOverflow中文版vc.ViewPage" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
    Home Page
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">    

<form id="form1" runat="server">    
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePageMethods="True">
</asp:ScriptManager>   

<script src="../../Scripts/jquery-1.4.1.js" type="text/javascript"></script>   

<script>
function test() 
{
  alert("Here");  
  $.getJSON(
    "/Home/Test", null, function(data, status) { alert("Success!"); alert(data); });
};      
</script>

<asp:Button ID="Button1" runat="server" Text="Call Page Methods" OnClientClick="return test()"/> 

</form>        

</asp:Content>

And my server side code is:

public JsonResult Test()
{
  string fooString = "test";
  return Json(fooString, JsonRequestBehavior.AllowGet);  
}


I think you are mixing some notions here. ASP.NET and ASP.NET MVC is not the same thing. From your code snippet I assume this is an ASP.NET MVC application (your view inherits from System.Web.Mvc.ViewPage). In ASP.NET MVC application <asp:Button runat="server" and <form runat="server"> and <asp:ScriptManager are no longer used, you can forget about those and there are no page methods, there are controllers and actions.

So you could do the following in your view:

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">    

    <script src="../../Scripts/jquery-1.4.1.js" type="text/javascript"></script>   
    <script type="text/javascript">
    $('#btnTest').click(function() {
        $.getJSON('/Home/Test', null, function(data) { 
            alert("Success!");
        });
        return false;
    });
    </script>
    <input type="button" id="btnTest" name="test" />
</asp:Content>
0

精彩评论

暂无评论...
验证码 换一张
取 消