如何使用javascript(aspx)从客户端调用服务器端(aspx.cs)中的非静态方法....?
据我所知,我可以从客户端调用服务器端的静态方法......
服务器端:
[WebMethod]
public static void method1()
{
}
客户方:
<script language="JavaScript">
function keyUP()
{
PageMethods.method1();
}
</script>
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePageMethods="true">
</asp:ScriptManager>
有效。现在如何从客户端调用非静态方法?
答案 0 :(得分:17)
您可以使用简单的.asmx页面而不是代码隐藏页面来避免静态约束。
1)使用AJAX Enable ASP.NET模板打开新网站(它将必要的引用放在web.config中)
2)SIMPLESERVICE.ASMX - 添加一个新的.asmx Web服务(我称之为我的SimpleService.asmx) 请注意[System.Web.Script.Services.ScriptSerive]修饰以及SimpleService类实现Webservice。
<%@ WebService Language="C#" Class="SimpleService" %>
using System;
using System.Web.Services;
[System.Web.Script.Services.ScriptService]
public class SimpleService : WebService
{
[WebMethod]
public string GetMessage(string name)
{
return "Hello <strong>" + name + "</strong>, the time here is: " + DateTime.Now.ToShortTimeString();
}
}
3)DEFAULT.ASPX - 要使用它,请在脚本管理器中引用该服务,然后您就可以运行了。在我的Javascript中,我调用了class.method - SimpleService.GetMessage。
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Untitled Page</title>
<script language="javascript" type="text/javascript">
function callServer() {
SimpleService.GetMessage($get("Name").value, displayMessageCallback);
}
function displayMessageCallback(result) {
$get("message").innerHTML = result;
}
</script>
</head>
<body>
<form id="form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server" >
<Services>
<asp:ServiceReference Path="~/SimpleService.asmx" />
</Services>
</asp:ScriptManager>
<div>
</div>
<h1>Hello World Example</h1>
<div>
Enter Name: <input id="Name" type="text" />
<a href="javascript:callServer()">Call Server</a>
<div id="message"></div>
</div>
</form>
</body>
</html>
我使用了我从Scott Gu找到的例子 Found Here.
答案 1 :(得分:7)
不,你不能从客户端本身调用非静态方法。我曾尝试过一次,但它很难看(我也使用过jQuery ajax)。只需使用带有方法名称的ajax调用页面作为查询字符串参数,然后在服务器端检查参数并调用相关方法。但正如我告诉你的那样,它非常丑陋:(
$.ajax({'/mypage.aspx?m=mymethod',......}); //this is not correct syntax
在服务器端:
protected void Page_Load(object sender, EventArgs e)
{
if(!Request.QueryString.HasKeys() ||
string.IsNullOrEmpty(Request.QueryString["m"]))
{
//return error or something relevant to your code
}
var m = Request.QueryString["m"];
switch(m)
{
case "a":
a();
break;
.....
.....
}
}
答案 2 :(得分:2)
C#
public string LoadString() {
return "my string";
}
JS / jQuery的
$('#txt').val(<%= LoadString() %>);
答案 3 :(得分:1)
实际上,你不能以这种方式调用非静态方法。
当您调用PageMethod时,您基本上是在调用特殊的Web服务。此功能仅适用于同一页面上的静态方法。
答案 4 :(得分:1)
如果要使用相同的功能调用它,可以使用以下代码:
[WebMethod]
public static void method1()
{
ClassOfNonStaticFunction obj = new ClassOfNonStaticFunction();
obj.yourFunctionName(ParametersIfAny);
}
答案 5 :(得分:0)
作为普拉米利亚的答案 我想你想要一个带有来自客户端的参数的函数,该函数在示例中实现 - &gt; CallServer(arg1,arg2)
<%@ Page Language="C#" AutoEventWireup="true" %>
<%@ Implements Interface="System.Web.UI.ICallbackEventHandler" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html >
<head runat="server">
<title>Client Callbacks</title>
<script runat="server">
public void RaiseCallbackEvent(String eventArgument)
{
// Processes a callback event on the server using the event
// argument from the client.
}
public string GetCallbackResult()
{
// Returns the results of a callback event to the client.
string dateString = DateTime.Now.ToLongDateString();
return dateString;
}
void Page_Load(object sender, EventArgs e)
{
ClientScriptManager cm = Page.ClientScript;
String cbReference = cm.GetCallbackEventReference(this, "arg",
"ReceiveServerData", "");
String callbackScript = "function CallServer(arg, context) {" +
cbReference + "; }";
cm.RegisterClientScriptBlock(this.GetType(),
"CallServer", callbackScript, true);
}
</script>
<script type="text/javascript">
function ReceiveServerData(arg, context) {
Message.innerText = "Date from server: " + arg;
}
</script>
</head>
<body>
<h2>Client Callbacks Without Postbacks</h2>
<form id="form1" runat="server">
<input type="button" value="Callback"
onclick="CallServer('1', alert('Callback sent to Server'))" />
<br />
<span id="Message"></span>
</form>
</body>
</html>
答案 6 :(得分:0)
我最终使用隐藏字段以防有人读到这个字段。我可以在函数下设置c#中的值,然后在javascript中读取它。
答案 7 :(得分:-4)
Dave详细介绍了如何使用jquery ajax从客户端调用页面方法。一般的想法是这样的(如果你发现任何问题请参考戴夫的网站)。
C#代码:
[WebMethod]
public static string yourmethod(/*params*/)
{
return "Hello World!"
}
ASPX:
$.ajax({
type: 'POST',
data: /*Your Data*/,
dataType: 'JSON',
contentType: 'application/json',
url: '/yourpage.aspx/yourmethod',//Method to call
success: function(result, status) {
//handle return data
},
error: function(xhr, status, error) {
//handle error
}
});