第一章、 Asp.net中服务端控件事件是如何触发的

Asp.net 中在客户端触发服务端事件分为两种情况:
  
  一.   WebControls中的Button 和HtmlControls中的Type为submit的HtmlInputButton
  

   这两种按钮最终到客户端的表现形式为: <input name="Submit1" id="Submit1" type="submit" value=”Submit”>,这是Form表单的提交按钮,点击以后会作为参数发送到服务端,参数是这样的: 控件的name属性=控件的value值,对应上面的例子就是:Submit1= Submit。 服务端会根据接收到的控件的name属性的这个key来得知是这个按钮被点击了,从而在服务端触发这个按钮的点击事件。
  
  二.   HtmlControls 中的 Type为button的HtmlInputButton 和其它所有的控件事件,比如LinkButton点击,TextBox的Change事件等等:
  

  这些事件在客户端产生后会经过一个统一的机制发送到服务端。
  
  1.    首先asp.net页框架会使用两个Hidden域来存放表示是哪个控件触发的事件,以及事件的参数:
  
  <!―表示触发事件的控件,一般是这个控件的name -->
  
  <input type="hidden" name="__EVENTTARGET" value="" />
  
  <!―表示触发事件的参数,一般是当某个控件有两个以上的事件时,用来区别是哪个事件 -->
  
  <input type="hidden" name="__EVENTARGUMENT" value="" />
  
  2.    服务端会生成一个jscript的方法来处理所有这些事件的发送,这段代码是:
  
  <script language="javascript">
  
  <!--
  
  function __doPostBack(eventTarget, eventArgument) {
  
  var theform = document.WebForm2;
  
  theform.__EVENTTARGET.value = eventTarget;
  
  theform.__EVENTARGUMENT.value = eventArgument;
  
  theform.submit();
  
  }
  
  // -->
  
  </script>
  
  3.    每个会引发服务端事件的控件都会在响应的客户端事件中调用上面的代码:
  
  比如,HtmlControls 中的 Type为button的HtmlInputButton的点击事件
  
   <!―客户端的点击事件调用__doPostBack,eventTarget 参数为'Button2',表示是name为'Button2’控件触发的事件,eventArgument 为空,表示这个Type为button的HtmlInputButton只有一个客户端触发的服务端事件-->
  
  < input language="javascript" οnclick="__doPostBack('Button2','')" name="Button2" id="Button2" type="button" value="Button" />
  
  又比如,TextBox控件的Change事件
  
   <!―客户端的onchange事件调用__doPostBack,eventTarget 参数为’TextBox1’,表示是name为’TextBox1’控件触发的事件,而TextBox控件只有一个客户端触发的服务端事件 TextChanged,故服务器就会去触发这个TextBox的TextChanged事件->
  
  <input name="TextBox1" type="text" id="TextBox1" οnchange="__doPostBack('TextBox1','')" language="javascript" />
  
   4.    客户端触发事件后调用__doPostBack方法,将表示触发的控件源的eventTarget 和事件参数eventArgument分别付给两个隐藏域__EVENTTARGET和__EVENTARGUMENT,然后提交Form,在服务端根据 __EVENTTARGET和__EVENTARGUMENT来判断是哪个控件的什么事件触发了。

第二章 PostBack的原理

__doPostBack是一个纯粹并且是非常简单的javascript函数,大部分的页面PostBack都是由它触发的。注意,这里是“大部分”,因为只有两

个Web Server Control    会自己触发页面的PostBack,其它的所以控件都是通过__doPostBack函数触发页面的PostBack,那先来看一下这个函

数的定义吧:

CODE1:

<input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />

<input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />

function __doPostBack(eventTarget, eventArgument) {

if (!theForm.onsubmit || (theForm.onsubmit() != false)) {

theForm.__EVENTTARGET.value = eventTarget;

theForm.__EVENTARGUMENT.value = eventArgument;

theForm.submit();

}

}

通过上面的代码可以看到,__doPostBack带有两个参数,eventTarget是标识将要引发页面PostBack的控件ID, eventArgument参数提供了在引发页面PostBack事件时所带的额外参数。当然这个函数被函数时,这两个参数的值将赋值给页面的两个隐含变 量__EVENTTARGET和__EVENTARGUMENT,然后调用页面的submit方法提交页面表单。这就是为什么我们可以通过 Request.Form[“__EVENTTARGET”]获取得到引发页面PostBack的控件ID的原因。

了解了__doPostBack函数后,我们可以很容易的利用它非常方便地自己触发自定义的PostBack事件。那上面也说了,大部分的控件都是调用

第三章 Button PostBack做法

引了页面的PostBack,只有两个控件是例外,Button 和 ImageButton,正是因为它们不是通过调用__doPostBack来回发事件,所以通过表单隐含变量__EVENTTARGET和 __EVENTARGUMENT是无法获取得到引发PostBack的Button或ImageButton的ID和参数值的,可通过下面的方式实现

1) 在页面中加如 LinkButton ,页面就会在页面中加载POSTBACK所需的JS

<input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />

<input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />

function __doPostBack(eventTarget, eventArgument) {

if (!theForm.onsubmit || (theForm.onsubmit() != false)) {

theForm.__EVENTTARGET.value = eventTarget;

theForm.__EVENTARGUMENT.value = eventArgument;

theForm.submit();

}

}

2)利用GetPostBackEventReference给客户端生成__doPostBack()
如:

比如前台页面

<asp:Button id="Button1" runat="server" Text="Button"></asp:Button>

(1)

<a href="#" onclick="document.getElementById('Button1').click()">触发服务器端按钮事件</a>

(2)
利用GetPostBackEventReference给客户端生成__doPostBack()
前台

<a href="#" onclick="<%=PostBack()%>">触发服务器端按钮事件</a>

后台

protected string PostBack()
        {
            return this.Page.GetPostBackEventReference(this.Button1,"haha");
        }

通过__EVENTARGUMENT="haha"可以判断是不是点了那个链接的PostBack
把Button1的按钮事件这么写:

if(Request["__EVENTARGUMENT" ]=="haha")
            {
                Response.Write("这个是链接的PostBack");
            }
            else
            {
                Response.Write("这个不是链接的PostBack");
            }

理解 __doPostBack--2相关推荐

  1. 深入理解 __doPostBack

    在我的随笔<Page,你是怎样处理回发事件的?>中曾提出一个疑问,如何得到引起页面PostBack的控件?通过阅读Page类的源码,误打误撞,无意中看到了__EVENTTARGET和__E ...

  2. 理解 __doPostBack(转)

    在我的随笔<Page,你是怎样处理回发事件的?>中曾提出一个疑问,如何得到引起页面PostBack的控件?通过阅读Page类的源码,误打误撞,无意中看到了__EVENTTARGET和__E ...

  3. [转]深入理解 __doPostBack

    在我的随笔<Page,你是怎样处理回发事件的?>中曾提出一个疑问,如何得到引起页面PostBack的控件?通过阅读Page类的源码,误打误撞,无意中看到了__EVENTTARGET和__E ...

  4. 【ASP.NET】 【防止连续多次点击提交按钮 导致页面重复提交】

    最近做项目遇到了这样的情况: 公司网络比平常慢了不少,在点击保存按钮提交页面后需等待挺长的一段时间,忍不住手贱点多了几次,当提交完成后发现数据库语句执行异常. 两种验证方式: 第1种: aspx页面按 ...

  5. 收藏:asp.net

    CSDN =================================================== isual Studio 2008简体中文试用版(90天)变成永久正式版的两种方法  ...

  6. ASP.NET WebForm Best Practice 之PostBack

    关于PostBack,我曾经也写过一篇博客<深入理解 __doPostBack>.在这篇文章里有对PostBack进行了一些研究,现在看来研究的还是不够深入.不过从原理上来说,ASP.NE ...

  7. 深入理解asp.net中的 __doPostBack函数

    前段时间做一个.net网站的时候,用到了模拟前端按钮刷新updatePanel进行局部刷新的时候,遇见了这个问题,当时没顾上记下来,查看网上资料,记下来留着以后查看. 很早以前,当我刚接触asp.NE ...

  8. ASP.Net中OnBeforeUnLoad事件中调用__doPostBack不起作用?

    我想当页面离开时,调用__doPostBack,但是服务器端总是得不到PostBack通知. function test() {    __doPostBack('Button1',''); }   ...

  9. 通用解题法——回溯算法(理解+练习)

    积累算法经验,积累解题方法--回溯算法,你必须要掌握的解题方法! 什么是回溯算法呢? 回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就&quo ...

  10. stream流对象的理解及使用

    我的理解:用stream流式处理数据,将数据用一个一个方法去 . (点,即调用) 得到新的数据结果,可以一步达成. 有多种方式生成 Stream Source: 从 Collection 和数组 Co ...

最新文章

  1. Python导入其他文件中的.py文件 即模块
  2. python实现实例_用python语言实现斗地主基础版-案例
  3. 一个小游戏Digger for .NET!
  4. 什么是lamda表达式?
  5. docker-compose配置redis服务
  6. C++命名(自定义)
  7. click vue 重复调用_VUE防止多次点击,重复请求
  8. python爬虫 正则表达式 re.finditer 元字符 贪婪匹配 惰性匹配
  9. SharePoint 2010 添加“我的链接”菜单
  10. jdk Comparator接口
  11. 计算机与信息工程学院参与运动会,我院成功举办2018秋季运动会
  12. 【优化分类】基于matlab GA优化GRNN超参数分类【含Matlab源码 1399期】
  13. 【无标题】如何做APP客户端数据埋点
  14. 计算机工程专业院校排名,2017美国计算机工程专业院校排名
  15. Taichi安装与应用
  16. Excel技巧--数据不能按照1-100来排列
  17. 【Android】【自动填充】自定义AutofillService(二):编写AutofillService代码
  18. 模糊数学简介与模糊综合评价法
  19. 严重性代码说明项目文件行 禁止显示状态错误 C4996 scanf
  20. Python卸载时发生严重错误

热门文章

  1. 【人民币识别】基于matlab GUI RGB和BP神经网络的人民币识别系统【含Matlab源码 097期】
  2. 世界第一个聊天机器人源代码_这是世界上第一个“活着”的机器人
  3. python:读取mat文件
  4. 计算机网络相关词汇,计算机网络英语词汇
  5. html字体溢出问题,CSS教程:关于文字溢出问题的研究
  6. Java一个月学到springboot_从零开始学SpringBoot如何开始使用图文详解
  7. vim无法写入hosts文件(提示hosts是一个只读文件)
  8. 制造行业IT运维管理解决方案
  9. Nagios中NSClient++监控Windows主机
  10. 从零到实现Shiro中Authorization和Authentication的缓存