Asp.net回调技术Callback学习笔记_实用技巧

.aspx:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>无标题页</title> 

<script type="text/javascript"> 

//向服务器传递参数
function DoSearch(){
var firstName=document.getElementById("TextBox1").value;
CallServer(firstName,"");
} 

//得到服务器的数据
function ReceiveServerData(txtUserInfo){
Results.innerHTML=txtUserInfo;
} 

//设置每1秒执行一次
setInterval("DoSearch()",1000);
</script> 

</head>
<body>
<form id="form1" runat="server">
<div>
姓名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<br />
<span id="Results" style=" width:500px;"></span>
</div>
</form>
</body>
</html>
[/code]
.aspx.cs
[code]
using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Data.SqlClient; 

public partial class _Default : System.Web.UI.Page, ICallbackEventHandler
{
protected string txtUserInfo; 

protected void Page_Load(object sender, EventArgs e)
{
//获取一个对客户端函数的引用
string cbReference = Page.ClientScript.GetCallbackEventReference(this, "arg", "ReceiveServerData", "context");
//动态注册回调函数
string callbackScript = "function CallServer(arg,context)" + "{" + cbReference + "};";
//引发callbackScript
Page.ClientScript.RegisterStartupScript(this.GetType(), "CallServer", callbackScript, true);
} 

//引发Callback事件处理
public void RaiseCallbackEvent(string txtFirstName)
{
if (txtFirstName != null)
{
String connString = System.Configuration.ConfigurationManager.ConnectionStrings["sqlserver2008"].ToString(); 

SqlConnection conn = new SqlConnection(connString); 

conn.Open(); 

SqlCommand comm = new SqlCommand("select * from zzx where [name]=@name", conn); 

comm.Parameters.Add("@name", SqlDbType.VarChar).Value = txtFirstName; 

SqlDataReader reader = comm.ExecuteReader(CommandBehavior.CloseConnection);
if (reader.Read())
{
txtUserInfo = "员工编号:" + reader["id"].ToString() + "<br>";
txtUserInfo += "员工姓名:" + reader["name"].ToString() + "<br>";
txtUserInfo += "地址:" + reader["address"].ToString() + "<br>";
txtUserInfo += "服务器查询时间:" + DateTime.Now.ToString();
}
else
{
if (string.IsNullOrEmpty(txtFirstName))
{
txtUserInfo = "请输入姓名";
}
else
{
txtUserInfo = "查无此人";
}
} 

comm.Dispose();
reader.Dispose();
conn.Dispose();
}
} 

//得到回调的结果,返回给客户端
public string GetCallbackResult()
{
return txtUserInfo;
} 

}

简化版(偷懒一下):

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>无标题页</title> 

<script type="text/javascript">
function OnCallBack(txtUserInfo,context){
Results.innerHTML=txtUserInfo;
}
</script> 

</head>
<body>
<form id="form1" runat="server">
<div>
姓名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<input id="Button2" type="button" value="button"
onclick="<%=Page.ClientScript.GetCallbackEventReference(this, "document.getElementById('TextBox1').value", "OnCallBack",null)%>" />
<br />
<span id="Results" style="pink; width: 500;"></span>
</div>
</form>
</body>
</html>
.aspx.cs

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Data.SqlClient;
using System.Text;
public partial class _Default : System.Web.UI.Page, ICallbackEventHandler
{
protected StringBuilder txtUserInfo; 

protected void Page_Load(object sender, EventArgs e)
{ 

} 

public string GetCallbackResult()
{
return txtUserInfo.ToString();
} 

public void RaiseCallbackEvent(string txtFirstName)
{
txtUserInfo = new StringBuilder();
String connString = ConfigurationManager.ConnectionStrings["sqlserver2008"].ToString();
SqlConnection conn = new SqlConnection(connString);
conn.Open();
SqlCommand comm = new SqlCommand("select * from zzx where [name]=@name", conn);
comm.Parameters.Add("@name", SqlDbType.VarChar).Value = txtFirstName;
SqlDataReader reader = comm.ExecuteReader(CommandBehavior.CloseConnection);
if (reader.Read())
{
txtUserInfo.Append("员工编号:" + reader["id"].ToString() + "<br>");
txtUserInfo.Append("员工姓名:" + reader["name"].ToString() + "<br>");
txtUserInfo.Append("地址:" + reader["address"].ToString() + "<br>");
txtUserInfo.Append("查询时间:" + DateTime.Now.ToString());
}
else
{
if (txtFirstName == string.Empty)
{
txtUserInfo.Append("请输入姓名");
}
else
{
txtUserInfo.Append("查无此人");
}
reader.Dispose();
comm.Dispose();
conn.Dispose();
}
}
}

示例3:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs" Inherits="Default3" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>无标题页</title>
<script type="text/javascript">
//客户端执行的方法
//下面的方法是接收并处理服务器方法返回的结果
function Success(args,context){
message.innerHTML=args;
} 

//下面的方式是当接收服务器方法处理的结果发生异常时调用的方法
function Error(){
message.innerHTML="发生了异常!";
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
用户名:<input type="text" id="txtUserName" onblur="CallServerMethod(txtUserName.value,null)" />
<span id="message"></span>
<br />
密码:<input type="password" size="10" maxlength="20" id="txtPwd" />
</div>
</form>
</body>
</html>
[code]
public partial class Default3 : System.Web.UI.Page,ICallbackEventHandler //实现ICallbackEventHandler接口
{ 

String result = String.Empty; 

protected void Page_Load(object sender, EventArgs e)
{
//获取当前页的ClientScriptManager的引用
ClientScriptManager csm = Page.ClientScript;
/*获取回调的引用.会在客户端生成WebForm_DoCallback方法,
* 调用它来达到异步调用.这个方法是微软写的方法,会被发送
到客户端*/
/*注意这里的"Success"和Error两个字符串分别是客户端代码中
*定义的两个javascript函数*/
//下面的方法最后一个参数的意义:true表示执行异步回调,false标志执行同步回调
String reference = csm.GetCallbackEventReference(this, "args", "Success", "", "Error", true);
String callbackScript = "function CallServerMethod(args,context){\n"+
reference+";\n }";
//向当前页面注册javascript脚本代码
csm.RegisterClientScriptBlock(this.GetType(), "CallServerMethod",callbackScript,true);
} 

#region ICallbackEventHandler 成员 

/// <summary>
/// 返回回调方法执行结果的方法
/// </summary>
public string GetCallbackResult()
{
return result;
} 

/// <summary>
/// 在服务器端运行回调方法
/// </summary>
public void RaiseCallbackEvent(string eventArgument)
{
if (eventArgument.ToLower().IndexOf("admin")!=-1)
{
result =eventArgument+ "不能作为用户注册.";
}
else
{
result = eventArgument + "可以注册.";
}
} 

#endregion
}

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索asp.net
, callback
回调
,以便于您获取更多的相关知识。

时间: 2024-10-30 01:11:21

Asp.net回调技术Callback学习笔记_实用技巧的相关文章

asp.net Linq to Xml学习笔记_实用技巧

加上之前学习过Linq to Entity,因此学习起来也比较随心应手. 以下是项目中某个底层的代码,记下做个备忘,如果能给新手学习Linq to Xml带来帮助,那就再好不过了 XML文件的格式: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <configuration> <OPsystemConfig> <MemberCenter> <DomainNam

值得收藏的asp.net基础学习笔记_实用技巧

值得收藏的asp.net基础学习笔记,分享给大家. 1.概论 浏览器-服务器 B/S 浏览的  浏览器和服务器之间的交互,形成上网B/S模式 对于HTML传到服务器  交给服务器软件(IIS)  服务器软件直接读取静态页面代码,然后返回浏览器 对于ASPX传达服务器  交给服务器软件(IIS)   IIS发现自己处理不了aspx的文件,就去映射表根据后缀名里找到响应的处理程序(isapi,服务器扩展程序) 问题:IIS如何调用可扩展程序? 答:可扩展程序首先就是按照IIS提供的借口实现代码,所以

ASP.NET MVC学习笔记_实用技巧

网上关于ASP.NET MVC的系列教程有好几个,所以就不从头开始介绍了,结尾处给大家推荐了几个链接,需要的话可以从头系统的看看. 1.ASP.NET MVC介绍及与ASP.NET WebForm的区别 刚开始为了搞清楚ASP.NET MVC到底值不值得用,翻来覆去想了一个多礼拜,看了好多资料和评论,最后决定还是值得一用.MVC不是一个简单的设计模式,更像一种架构模式,或者一种思想,刚开始一听MVC想到的就是模板引擎,NVelocity,StringTempleate等,但感觉如果只是为了用模板

ASP.NET预备知识学习笔记_实用技巧

.NET FrameWork框架 是一套应用程序开发框架,主要目的提供一个开发模型. 主要的两个组件:     公共语言运行时(Common Language Runtime)(CLR): 提供内存管理.线程管理和远程处理等核心服务,并且还强制实施严格的安全类型,提高代码的安全性和可靠想. .NET  Framework类库: 与CLR紧密集成,可以使用它开发多种应用程序和服务.主要包括控制台应用程序.Windows窗体应用程序.WindowsPresentationFoundation(WPF

那些年,我还在学asp.net(一) 学习笔记_基础应用

那些年到此,基本学习了前端的基本知识,那些年的第四课就是asp.net,当然那时看了很多教程,比如说:天轰穿,当然天轰穿说得比较多,如面向对象,C#知识,由于当时上过C++,所以就没有看这些,直接从asp.net开始,主要是学习一下asp.net用到的一些基本控件,后来感觉差不多了就不再看了,开始学习asp.net的数据教程(scott教程),那些年慢慢的走向web开发了.    先还是看一下asp.net中的一些基本的控件的使用. 一.GridView控件的使用 1.GridView 是asp

那些年,我还在学习asp.net(二) 学习笔记_基础应用

那些年,我还在学习asp.net(二) 那些年觉得看视频是很轻松的了解一个东西,但是这样的不足就是感觉太慢了,没有看书来得快,所以在有了一些了解后,还得看点书,也许书上的不一定好,但书上会把每一个应该说到的地方说到,好有个初步的认识.比如说.NET平台.组件等知识的介绍,所以,那些年就开始了asp.net方面的进一步学习. 一.学习asp.net的准备知识 正如我前面那些年所学习的,在开始之前得对它们有一定的认识: 1.  html语言的基本使用 2.  CSS+DIV的学习,撑握基本的布局 3

比较完整的 asp.net 学习流程_实用技巧

如果你已经有较多的面向对象开发经验,跳过以下这两步: 第一步 掌握一门.NET面向对象语言,C#或VB.NET 我强烈反对在没系统学过一门面向对象(OO)语言的前提下去学ASP.NET. ASP.NET是一个全面向对象的技术,不懂OO,那绝对学不下去! 第二步 对.NET Framework类库有一定的了解 可以通过开发Windows Form应用程序来学习.NET Framework.ASP.NET是建构在.NET Framework之上的技术,你对.NET Framework了解得越深,学习

当年学习ADO.NET的笔记_实用技巧

那些年我还在学ADO.NET 那些年学习了ASP.NET后又开始学习ASP.NET的新知识,ADO.NET用于访问数据库,一般可以分为连接模式和非连接模式.连接模式指的是在访问数据时,一直与数据库保持连接,访问完数据后才与数据库断开连接,主要采用的ADO.NET对象是Connection.Command.DataReader等:连接模式指的是通过数据集的方式对数据库进行操作,将数据读到内存中,从而完成数据的操作,数据集会自动更新到数据库,主要采用ADO.NET对象是DataAdapter.Dat

基于ASP.NET MVC的ABP框架入门学习教程_实用技巧

为什么使用ABP我们近几年陆续开发了一些Web应用和桌面应用,需求或简单或复杂,实现或优雅或丑陋.一个基本的事实是:我们只是积累了一些经验或提高了对,NET的熟悉程度. 随着软件开发经验的不断增加,我们发现其实很多工作都是重复机械的,而且随着软件复杂度的不断提升,以往依靠经验来完成一些简单的增删改查的做法已经行不通了.特别是用户的要求越来越高,希望添加的功能越来多,目前这种开发模式,已经捉襟见肘.我很难想象如何在现有的模式下进行多系统的持续集成并添加一些新的特性. 开发一个系统时,我们不可避免的