zoukankan      html  css  js  c++  java
  • __doPostBack用法

         今天写ajax程序时,需要重新从后台加载数据,所以用了__doPostBack方法。 __doPostBack并不是我自己写的方法,是由asp.net 自己加入页面中的方法。我们运行Asp.net程序后,会在生成的html源码中看到__doPostBack方法,其代码如下:

    代码
    <script type="text/javascript">
    //<![CDATA[
    var theForm = document.forms['aspnetForm'];
    if (!theForm) {
        theForm 
    = document.aspnetForm;
    }
    function __doPostBack(eventTarget, eventArgument) {
        
    if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
            theForm.__EVENTTARGET.value 
    = eventTarget;
            theForm.__EVENTARGUMENT.value 
    = eventArgument;
            theForm.submit();
        }
    }
    //]]>
    </script>

    __doPostBack说明:     __doPostBack可以实现客户端控件调用服务器端控件的响应。
    __doPostBack方法的格式为: __doPostBack(eventTarget,eventArgument)
       参数:  eventTarget:是要触发的服务器控件的客户端ID
             eventArgument:参数

    这个两个值在后台可以通过下边方法得到:
        Request["__EVENTTARGET"]     :获取得到引发页面PostBack的控件ID
        Request["__EVENTARGUMENT"]: 获取参数。

    例子,回发UpDataPanel,通过参数获取资料。
    1)首先调用doPostBack触发回发: 

    __doPostBack('ctl00_ContentPlaceHolder1_upModulePower', 'jsPostback')

     说明:

      ctl00_ContentPlaceHolder1_upModulePower:是加了母版页后的生成的客户端ID。

      jsPostback:用于判断是不是通过js控件触发的回发。因为UpDatePanel中会有其它服务器控件解发的回发,所以用此参数加以区分。

     2) 在后台PageLoad中得到参数,并取数据。

    //判断是否是js触发的回发
    if (Request["__EVENTARGUMENT"== "jsPostback")
    {
        
    //此处调用相关后台方法
       
    //……
    }


     
    其它问题:
        但是在我们调用__doPostBack函数时,有些时候调用这个函数会出现"对象不存在"的脚本错误? 那是因为Html里面没有__doPostBack函数体,一般在拖放那些有自动回传功能的控件时,当把他的autoPostback属性设为True,在运行的时候系统会自动添加__doPostback函数体。当然最直接的办法就是添加一个LinkButton。在页面中加如 LinkButton ,页面就会在页面中加载POSTBACK所需的JS,然后把其Text属性设为空,切记不要设 Visible属性,因为如果Visible=false,在翻译成Html时,直接就忽略LinkButton的存在了

  • 相关阅读:
    vuex 命名空间
    vue-touchjs
    Jackson最简单用法
    Bootstrap登录样式
    Left/Right/Inner Join用法和区别
    VS2015安装提示出现“安装包丢失或损坏”解决方法
    HTML之禁止输入文本
    jQuery之call()方法的使用
    jQuery操作cookie
    jQuery常用的查找Dom元素方法
  • 原文地址:https://www.cnblogs.com/scottckt/p/1769690.html
Copyright © 2011-2022 走看看