是否有可能在不同的页面上调用javascript中的[WebMethod]属性?即利用脚本以下的jquery ajax调用名为PageTwo.aspx页:含在不同的页面上从javascript调用页面的webmethod
[WebMethod]
public string PageOneMethodOne()
{
return "hello world";
}
是否有可能在不同的页面上调用javascript中的[WebMethod]属性?即利用脚本以下的jquery ajax调用名为PageTwo.aspx页:含在不同的页面上从javascript调用页面的webmethod
[WebMethod]
public string PageOneMethodOne()
{
return "hello world";
}
这是可能的,只要你指定正确的URL
$.ajax(
{
type: "POST",
url: "pageone.aspx/PageOneMethodOne",
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(msg)
{
//something
}
}
);
PageOne.aspx.cs。看看下面的表格:
<form id="form1" runat="server">
<div>
<div id="messages">
</div>
<input type="text" id="echo" /><input id="echoSubmit" value="Echo!" type="button"/>
</div>
和它相应的JavaScript:
<script type="text/javascript">
$(function() {
$('#echoSubmit').click(function() {
var mes = $('#echo').val();
var jsonText = JSON.stringify({ message: mes });
$.ajax({
type: "POST",
url: "SampleForm.aspx/SendMessage",
data: jsonText,
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (msg) {
$("#messages").append(msg.d);
}
});
});
});
</script>
点击echoSumbit按钮将输入框的内容发送到一个WebMethod上的另一个控件,SampleForm.aspx。下面是形式的代码隐藏:
public partial class SampleForm : System.Web.UI.Page
{
[WebMethod]
public static string SendMessage(string message)
{
return message;
}
}
在Chat.aspx的点击处理程序发送输入值SampleForm.aspx.cs,它返回所发送的值。返回的值将附加到.ajax调用的成功方法中的Chat.aspx中的div上。
谢谢@njebert,你能告诉我,页面上的方法必须是静态的吗? – hofnarwillie 2012-04-12 18:03:34
您可以使用.asmx代替代码隐藏来调用非静态方法 - http://stackoverflow.com/questions/1360253/call-non-static-method-in-server-sideaspx-cs-from -client侧使用JavaScript的 – njebert 2012-04-12 18:50:04
我想\你可以只要你指定正确的url到它 – 2012-04-12 16:52:40