我正在做一些简单的测试(准备一个更大的项目)来使用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;
}
}
}
答案 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;