asp.net2.0的客户端回调是一种很让人激动的方法,他能够让我们控制要提交什么数据给服务器而不用提交整个页面,同时服务器也只返回你所需要的数据而不要发回整个页面。
首先我们要说一个很重要的方法:getcallbackeventrefernce.我把我的理解写出来,可能是错误的,恳请指出,非常感谢!
getcallbackeventreference首先实现让客户端脚本有能力传递参数给服务器端的raisecallbackevent方法,然后返回raisecallbackevent方法的值给你在getcallbackeventrefernce方法中注册的一个参数(其实也是一个你要在客户端写的脚本)。调用getcallbackeventrefernce你必须从客户端脚本中传递给他两个参数,一个是要传递给raisecallbackevent事件的值,一个是context.
他的参数意义如下:
第一个:实现了icallbackeventhandler借口的页面或者服务器控件,写this代表但前页面。
第二个:代表你从要从客户端传递给服务器raisecallbackevent方法的值
第三个:你要在客户端写的一个js函数,同时,服务器也会把计算得到的数据传递给这个函数做为这个函数的参数。
第四个:context具体什么意思我也不太清楚getcallbackeventrefernce发送到了客户、端的代码是这样的:
webform_docallback('__page',arg,receiveserverdata,context,null,false)
那么我们要怎么样做才能够从客户端调用他呢?看到了三中方法:
第一种:在后台写个public string,在page_load中给他赋值为:=page.clientscript.getcallbackeventreference(this, "message", "showservertime", "context");注意在这里是page.clientscrip,因为他会返回个clientscriptmanager,clientscriptmanager管理所有的客户端脚本。然后在前台某个按钮的onclick事件里<%=那个public后台字符串%>.做个小实验代码如下:
前台servertime.aspx:为了方便去掉好多没用的html
<%@ page language="c#" codefile="servertime.aspx.cs" inherits="servertime_aspx" %>
<html>
<head>
<title>server time</title>
<script language="javascript">
function getservertime()
{
var message = '';
var context = '';
<%=scallbackfunctioninvocation%>
}
function showservertime(timemessage, context) {
alert('现在服务器上的时间是:\n' + timemessage);
}
</script>
</head>
<body>
<form id="mainform" runat="server">
<input type="button" value="得到服务器端时间" onclick="getservertime();" />
</form>
</body>
</html>
后台:
using system;
using system.web.ui;
public partial class servertime_aspx : page,icallbackeventhandler
{
//一定要实现icallbackeventhandler借口
public string scallbackfunctioninvocation;
void page_load(object sender, system.eventargs e)
{
scallbackfunctioninvocation = page.clientscript.getcallbackeventreference(this, "message", "showservertime", "context");
}
public string raisecallbackevent(string eventargument)
{
return datetime.now.tostring();
}
}
运行,点按钮结果如下:
第二种方法:在上面的方法中我们必须要在前台绑定后台,那么如果不绑定呢?我们这样做:
直接把getcallbackeventreference当做js函数中的一个实现内容,然后把这个js函数注册到客户端。
前台testpage代码:
<%@ page language="c#" autoeventwireup="true" codefile="testpage.aspx.cs" inherits="testpage" %>
<html>
<head>
<title>untitled page</title>
<script type="text/javascript">
function test()
{
var lb = document.getelementbyid("select1");
//取的那个下拉框
var con = lb.options[lb.selectedindex].text;
//得到你选择的下拉框的文本再调用呢个calltheserver,是一个由服务器端输出的js函数
calltheserver(con,'');
}
function receiveserverdata(rvalue)
{
results.innerhtml = rvalue;
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<select id="select1">
<option value=1 selected="selected">老鼠徒弟</option>
<option value=2>吴旗娃师傅</option>
</select>
<br />
<br />
<input onclick="test()" value="从服务器返回下拉框文本" type=button>
<br />
<br />
<span id="results"></span>
<br />
</div>
</form>
</body>
</html>
后台代码:
using system;
using system.data;
using system.configuration;
using system.collections;
using system.web;
using system.web.security;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.webcontrols.webparts;
using system.web.ui.htmlcontrols;
public partial class testpage : system.web.ui.page,system.web.ui.icallbackeventhandler
{
protected void page_load(object sender, eventargs e)
{
string cbreference = page.clientscript.getcallbackeventreference(this, "arg", "receiveserverdata", "context");
string callbackscript;
callbackscript = "function calltheserver(arg,context)" +"{ " + cbreference + "} ;";
page.clientscript.registerstartupscript(this.gettype(),"abcdefg",callbackscript, true);
//第四个参数代表是不是要自动给着脚本加上<script type="text/javascript"></script>标记,当然要加啊
}
public string raisecallbackevent(string eventargument)
{
return "你选择的是" + eventargument;
}
}
下面是执行结果:
第三种:前面两种都是<input type="button"的html控件,那么如果是服务器按钮呢?当然也可以,在后台添加服务器按钮的onclick 属性。
前台third.aspx代码:
<%@ page language="c#" autoeventwireup="true" codefile="third.aspx.cs" inherits="third" %>
<html>
<head>
<title>untitled page</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<select id="select1">
<option selected="selected" value=1>老鼠徒弟</option>
<option value=2>吴旗娃师傅</option>
</select>
<asp:button id="button1" runat="server" text="这是个服务器按钮" /></div>
<div id="div1" />
<script type="text/javascript">
function re(ret)
{
document.getelementbyid("div1").innerhtml = ret;
alert(ret);
}
</script>
</form>
</body>
</html>
后台代码:
using system;
using system.data;
using system.configuration;
using system.collections;
using system.web;
using system.web.security;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.webcontrols.webparts;
using system.web.ui.htmlcontrols;
public partial class third : system.web.ui.page,system.web.ui.icallbackeventhandler
{
protected void page_load(object sender, eventargs e)
{
//第四个参数为null,因为你不可能再在js中给他传参数了
string str = page.clientscript.getcallbackeventreference(this,"document.getelementbyid('select1')._
options[document.getelementbyid('select1').selectedindex].text","re",null);
//return false是为了防止提交窗体
button1.attributes.add("onclick",str+";return false;");
}
#region icallbackeventhandler members
public string raisecallbackevent(string eventargument)
{
if (eventargument == "老鼠徒弟")
{
return "老鼠徒弟:人生如鼠,不在仓就在厕!";
}
else
{
return "吴旗娃师傅:自信自强,乐观向上";
}
}
#endregion
}
小技巧,当你写完system.web.ui.icallbackeventhandler后,把鼠标移上去,那么system前面会有个小图表,点他会自动写好那个raisecallbackevent代码,效果如下;
第三个感觉最差!
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器