选择显示字体大小

asp.net2.0实现无刷新客户端回调

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   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons