.aspx:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
<%@ 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; } } |
简化版(偷懒一下):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
<%@ 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:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
<%@ 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 } |