我试图在我的代码中使用Jquery和Ajax调用一个简单的方法。但我每次都会得到404未找到的异常。不幸的是,这是一种Web表单解决方案所以我没有MVC的所有特权:(
它确实进入了javascript方法并提供警报但不会进入我的c#方法。我以前使用这个Jquery方法的经验是在MVC网站上。它与webforms网站兼容吗?
我的Javascript是:
$(document).ready(function() {
$('#btn_<%=UserStuff.tag %>').click(function() {
var value = $('#<%#Eval("tag") %>twink').val();
something(value);
});
});
function something(theval) {
alert(theval);
$.ajax({
type: "POST",
url: "/Default.aspx/MyMethod?something=" + theval,
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(msg) {
alert(msg);
}
});
}
}
我的C#代码是:
public JsonResult MyMethod(string something)
{
JsonResult ret = new JsonResult();
return ret;
}
提前致谢。
答案 0 :(得分:39)
您的方法返回JsonResult
。这是MVC特定的,您不能在webforms应用程序中使用它。
如果要在经典WebForms应用程序中调用代码中的方法,可以使用PageMethods:
[WebMethod]
public static string GetDate()
{
return DateTime.Now.ToString();
}
然后调用方法:
$.ajax({
type: 'POST',
url: 'PageName.aspx/GetDate',
data: '{ }',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function(msg) {
// Do something interesting here.
}
});
这是我为你写的一个完整的例子:
<%@ Page Language="C#" %>
<%@ Import Namespace="System.Web.Services" %>
<script type="text/C#" runat="server">
[WebMethod]
public static string SayHello(string name)
{
return "Hello " + name;
}
</script>
<!DOCTYPE html>
<html>
<head>
<title></title>
<script type="text/javascript" src="/scripts/jquery-1.4.1.js"></script>
<script type="text/javascript">
$(function () {
$.ajax({
type: 'POST',
url: 'default.aspx/sayhello',
data: JSON.stringify({ name: 'John' }),
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function (msg) {
// Notice that msg.d is used to retrieve the result object
alert(msg.d);
}
});
});
</script>
</head>
<body>
<form id="Form1" runat="server">
</form>
</body>
</html>
PageMethods不仅限于简单的参数类型。您可以使用任何类型作为输入和输出,它将自动进行JSON序列化。