如何在客户端调用服务端代码

简介:

比如我们在页面上有3个TextBox,3个Button,每个Button分别执行不同的动作。我们现在想在TextBox中检测是否按下了回车键,如果是则执行不同的Button调用。即TextBox1中按下回车就执行Button1的动作,......

测试中,我发现要调用服务器端代码必须调用__doPostBack函数,但该函数除了在放置有DataGrid控件的页面中会由系统产生外,其他的页面中并不存在。(可以通过查看源文件看到该代码)。这样我们必须手工在aspx中添加__doPostBack函数,和函数一起添加的还有两个隐藏元素,__EVENTTARGET和__EVENTARGUMENT,这是__doPostBack所必须的,实际上,.NET是把产生事件的元素名称以及参数传到,__EVENTTARGET和__EVENTARGUMENT。然后再调用Form的submit函数提交回服务器的,服务器端根据传回来的参数就知道是哪个控件被触发了,从而调用它的相应后端代码,然后再将新页面回送回客户端的。
以下是我的测试页面,其中使用了两种方法来检测TextBox中的按键
WebForm2.aspx
--------------------------------------------------------

ExpandedBlockStart.gif <% @ Page language="c#" Codebehind="WebForm2.aspx.cs" AutoEventWireup="false" Inherits="UTF8Test.WebForm2"  %>
None.gif
<! DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"  >
None.gif
< HTML >
None.gif 
< HEAD >
None.gif  
< title > WebForm2 </ title >
None.gif  
< meta  content ="Microsoft Visual Studio .NET 7.1"  name ="GENERATOR" >
None.gif  
< meta  content ="C#"  name ="CODE_LANGUAGE" >
None.gif  
< meta  content ="javascript"  name ="vs_defaultClientScript" >
None.gif  
< meta  content ="http://schemas.microsoft.com/intellisense/ie5" ; name ="vs_targetSchema" >
ExpandedBlockStart.gif  
< script  language ="javascript"  event ="onkeydown"  for ="TextBox1" >
InBlock.gif
InBlock.gif      
InBlock.gif   
if(event.keyCode==13)<!-- 注意大小写-->
ExpandedSubBlockStart.gif   
{
InBlock.gif    __doPostBack('Button1','');
InBlock.gif    
return false;<!--很重要,不然会选择Button1进行提交  -->
ExpandedSubBlockEnd.gif   }

InBlock.gif   
ExpandedBlockEnd.gif  
</ script >
ExpandedBlockStart.gif  
< script  language ="javascript"  event ="onkeydown"  for ="TextBox2" >
InBlock.gif
InBlock.gif      
InBlock.gif   
if(event.keyCode==13)
ExpandedSubBlockStart.gif   
{
InBlock.gif    __doPostBack('Button2','');
InBlock.gif    
return false;<!--很重要,不然会选择Button1进行提交  -->
ExpandedSubBlockEnd.gif   }

InBlock.gif   
ExpandedBlockEnd.gif  
</ script >
ExpandedBlockStart.gif  
< script  language ="javascript" >
InBlock.gif    
function keypress()
ExpandedSubBlockStart.gif    
{
InBlock.gif     
if(event.keyCode==13)
ExpandedSubBlockStart.gif   
{
InBlock.gif      
InBlock.gif    __doPostBack('Button3','');
InBlock.gif    event.keyCode
=0<!--很重要,不然会选择Button1进行提交  -->
InBlock.gif    
return false;<!--很重要,不然会选择Button1进行提交  -->
ExpandedSubBlockEnd.gif   }

ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif  
</ script >
None.gif 
</ HEAD >
None.gif 
< body  MS_POSITIONING ="GridLayout" >
None.gif  
< form  id ="Form1"  method ="post"  runat ="server" >
None.gif   
< input  type ="hidden"  name ="__EVENTTARGET" >   < input  type ="hidden"  name ="__EVENTARGUMENT" >
ExpandedBlockStart.gif   
< script  language ="javascript"  type ="text/javascript" >
InBlock.gif
<!--
ExpandedSubBlockStart.gif 
function __doPostBack(eventTarget, eventArgument) {
InBlock.gif  
var theform;
ExpandedSubBlockStart.gif  
if (window.navigator.appName.toLowerCase().indexOf("microsoft"> -1{
InBlock.gif   theform 
= document.Form1;
ExpandedSubBlockEnd.gif  }

ExpandedSubBlockStart.gif  
else {
InBlock.gif   theform 
= document.forms["Form1"];
ExpandedSubBlockEnd.gif  }

InBlock.gif  theform.__EVENTTARGET.value 
= eventTarget.split("$").join(":");
InBlock.gif  theform.__EVENTARGUMENT.value 
= eventArgument;
InBlock.gif  theform.submit();
ExpandedSubBlockEnd.gif }

InBlock.gif
// -->
ExpandedBlockEnd.gif
   
</ script >
None.gif   
< asp:button  id ="Button1"  style ="Z-INDEX: 101; LEFT: 192px; POSITION: absolute; TOP: 88px"  runat ="server"
None.gif    Text
="Button1" ></ asp:button >< asp:textbox  id ="TextBox1"  style ="Z-INDEX: 102; LEFT: 16px; POSITION: absolute; TOP: 88px"  runat ="server" ></ asp:textbox >
None.gif   
< asp:Button  id ="Button2"  style ="Z-INDEX: 103; LEFT: 192px; POSITION: absolute; TOP: 120px"  runat ="server"
None.gif    Text
="Button2" ></ asp:Button >
None.gif   
< asp:TextBox  id ="TextBox2"  style ="Z-INDEX: 104; LEFT: 16px; POSITION: absolute; TOP: 120px"  runat ="server" ></ asp:TextBox >
None.gif   
< asp:TextBox  id ="TextBox3"  style ="Z-INDEX: 105; LEFT: 16px; POSITION: absolute; TOP: 152px"  runat ="server" ></ asp:TextBox >
None.gif   
< asp:Button  id ="Button3"  style ="Z-INDEX: 106; LEFT: 192px; POSITION: absolute; TOP: 152px"  runat ="server"
None.gif    Text
="Button3" ></ asp:Button >
None.gif   
< asp:Label  id ="Label1"  style ="Z-INDEX: 107; LEFT: 24px; POSITION: absolute; TOP: 56px"  runat ="server" ></ asp:Label ></ form >
None.gif 
</ body >
None.gif
</ HTML >

WebForm2.aspx.cs
----------------------------------------------------------------------
None.gif using  System;
None.gif
using  System.Collections;
None.gif
using  System.ComponentModel;
None.gif
using  System.Data;
None.gif
using  System.Drawing;
None.gif
using  System.Web;
None.gif
using  System.Web.SessionState;
None.gif
using  System.Web.UI;
None.gif
using  System.Web.UI.WebControls;
None.gif
using  System.Web.UI.HtmlControls;
None.gif
None.gif
namespace  UTF8Test
ExpandedBlockStart.gif
{
ExpandedSubBlockStart.gif 
/// <summary>
InBlock.gif 
/// WebForm2 的摘要说明。
ExpandedSubBlockEnd.gif 
/// </summary>

InBlock.gif public class WebForm2 : System.Web.UI.Page
ExpandedSubBlockStart.gif 
{
InBlock.gif  
protected System.Web.UI.WebControls.TextBox TextBox1;
InBlock.gif  
protected System.Web.UI.WebControls.Button Button2;
InBlock.gif  
protected System.Web.UI.WebControls.TextBox TextBox2;
InBlock.gif  
protected System.Web.UI.WebControls.TextBox TextBox3;
InBlock.gif  
protected System.Web.UI.WebControls.Button Button3;
InBlock.gif  
protected System.Web.UI.WebControls.Label Label1;
InBlock.gif  
protected System.Web.UI.WebControls.Button Button1;
InBlock.gif 
InBlock.gif  
private void Page_Load(object sender, System.EventArgs e)
ExpandedSubBlockStart.gif  
{
InBlock.gif   
// 在此处放置用户代码以初始化页面
InBlock.gif
   TextBox3.Attributes.Add("onkeypress","keypress()");//注意大小写
ExpandedSubBlockEnd.gif
  }

InBlock.gif
ContractedSubBlock.gif  
Web 窗体设计器生成的代码
InBlock.gif
InBlock.gif  
private void Button1_Click(object sender, System.EventArgs e)
ExpandedSubBlockStart.gif  
{
InBlock.gif   Label1.Text 
= "1";
ExpandedSubBlockEnd.gif  }

InBlock.gif
InBlock.gif  
private void Button2_Click(object sender, System.EventArgs e)
ExpandedSubBlockStart.gif  
{
InBlock.gif   Label1.Text 
= "2";
ExpandedSubBlockEnd.gif  }

InBlock.gif
InBlock.gif  
private void Button3_Click(object sender, System.EventArgs e)
ExpandedSubBlockStart.gif  
{
InBlock.gif   Label1.Text 
= "3";
ExpandedSubBlockEnd.gif  }

ExpandedSubBlockEnd.gif }

ExpandedBlockEnd.gif}



本文转自高海东博客园博客,原文链接:http://www.cnblogs.com/ghd258/archive/2005/10/23/260240.html,如需转载请自行联系原作者
相关文章
|
2月前
|
存储 JSON 监控
源码分析Zabbix客户端如何向服务端发起请求
源码分析Zabbix客户端如何向服务端发起请求
29 2
|
Web App开发 缓存 网络协议
如何实现服务端向客户端推送数据
常见的http协议只能从客户端主动向服务端请求数据,而服务端无法向客户端发送数据.本文通过介绍几种方式来实现上述功能.
|
4月前
|
网络协议 Cloud Native
为什么服务端会有那么多的 TimeWait ?
为什么服务端会有那么多的 TimeWait ?
|
4月前
|
网络协议 算法 Java
gRPC 客户端调用服务端需要连接池吗?
gRPC 客户端调用服务端需要连接池吗?
|
6月前
|
Windows
WCF服务端调用客户端.
WCF服务端调用客户端.
|
SQL 安全 前端开发
服务端测试
大家好,我是阿萨。前几天我们讲了你了解客户端测试吗?和客户端对应的就是服务器端了。那么服务器端如何测试呢?服务器端相当于一个黑盒子,我们能接触到的只有前台向后端发送的API请求。所以服务器端测试也可以理解为API测试。
201 0
|
存储 Linux API
1.1 什么是客户端
1.1 什么是客户端
1.1 什么是客户端
|
运维 Java 数据库连接
排除法,先找客户端问题,再找服务端问题
先找客户端问题,再找服务端问题
56 0
|
JavaScript
服务器端解决JS跨域调用问题
一. 使用JSONp方式调用   不做详细讲解,可以参考jq文档   二. 服务端配置   修改Web.config 文件   客户...
880 0