Jquery AJAX与ASP.NET WebMethod返回整页

时间:2008-12-08 05:02:30

标签: asp.net jquery ajax

我正在做一些简单的测试(准备一个更大的项目)来使用JQuery AJAX调用ASP.NET WebMethod。在我的示例中,我的WebMethod返回一个简单的字符串。但是,当我尝试使用JQuery调用它时,我会返回整个HTML页面内容,而不仅仅是我的字符串。我错过了什么?

客户端:

$(document).ready(function ready() {
        $("#MyButton").click(function clicked(e) {
            $.post("Default.aspx/TestMethod",
                {name:"Bob"},
                function(msg) {
                    alert("Data Recieved: " + msg);
                },
                "html"
            );
        });
    });

服务器端:

using System;
using System.Web.Services;

namespace JqueryAjaxText
{
    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {

        }

        [WebMethod]
        public static string TestMethod(string name)
        {
            return "The value submitted was " + name;
        }
    }
}

4 个答案:

答案 0 :(得分:19)

查看此链接。我使用了他的一些其他帖子来成功调用WCF服务。请务必查看相关文章:

http://encosia.com/2008/05/29/using-jquery-to-directly-call-aspnet-ajax-page-methods/

阅读文章,但基本上是:

  $("#Result").click(function() {
    $.ajax({
      type: "POST",
      url: "Default.aspx/GetDate",
      data: "{}",
      contentType: "application/json; charset=utf-8",
      dataType: "json",
      success: function(msg) {
        $("#Result").text(msg.d);
      }
    });
});

答案 1 :(得分:9)

我认为我对JQuery的$ .post命令中的“type”参数感到困惑。在与一些人交谈之后,似乎调用WebMethod的返回类型必须是“json”。我试图使用“html”。一旦我将其改为“json”,然后一切正常。显然,用[WebMethod]修饰的方法只返回JSON,这就是我的挂机所在。

感谢您的回复。

答案 2 :(得分:3)

尝试将最后一个参数“html”更改为“text”。此参数指定要返回的数据类型。

答案 3 :(得分:0)

我遇到了完全相同的问题:WebMethod返回了整个HTML页面而不是预期的数据。对我来说,解决方案来自于更改〜/ App_Start / RouteConfig.cs 内的以下行:

settings.AutoRedirectMode = RedirectMode.Permanent;

settings.AutoRedirectMode = RedirectMode.Off;