zoukankan      html  css  js  c++  java
  • Page.MaintainScrollPositionOnPostBack 属性

    ASP.NET 的页面执行 PostBack 动作时,页面由伺服端重新传给客户端,而页面的垂直滚动条会跳回最上方,水平滚动条会跳回最左方。
    为了解决此情形,只要将
     Page MaintainScrollPositionOnPostBack 属性设为True 时,页面就会自动维护滚动条位置,它是如何实现这个动作的呢?

    当把 Page.MaintainScrollPositionOnPostBack = "True" 时,检视 HTML 原始码,可以发现它多了"__SCROLLPOSITIONX" "__SCROLLPOSITIONY" 这二个 HiddenField,这二个 HiddenField 主要是要来记录页面滚动条的水平及垂直位置。

        <input type="hidden" name="__SCROLLPOSITIONX" id="__SCROLLPOSITIONX" value="0" />
        
    <input type="hidden" name="__SCROLLPOSITIONY" id="__SCROLLPOSITIONY" value="204" />


    页面上也会多了以下这些
    JavaScript 程序代码,它主要是透过WebForm_SaveScrollPositionSubmit WebForm_RestoreScrollPosition 这二个函式来维护页面滚动条位置。

     1<script type="text/javascript">
     2<!--
     3theForm.oldSubmit = theForm.submit;
     4theForm.submit = WebForm_SaveScrollPositionSubmit;
     5
     6theForm.oldOnSubmit = theForm.onsubmit;
     7theForm.onsubmit = WebForm_SaveScrollPositionOnSubmit;
     8
     9theForm.oldOnLoad = window.onload;
    10window.onload = WebForm_RestoreScrollPosition;
    11// -->
    12</script>

    当页面Submit 时会利用WebForm_SaveScrollPositionSubmit 函式来记录页面目前的水平及垂直滚动条位置,将水平滚动条位置记录于"__SCROLLPOSITIONX" 这个 HiddenField,垂直滚动条位置记录于"__SCROLLPOSITIONY" 这个 HiddenField

     PostBack 后页面重新加载后,会利用WebForm_RestoreScrollPosition 函式来回复页面滚动条位置,也就是将记录在"__SCROLLPOSITIONX" "__SCROLLPOSITIONY" 这二个 HiddenField 的值,重新设定页面的水平及垂直滚动条位置,如此就达到维护页面滚动条位置的动作了。

  • 相关阅读:
    ComboBox.DoubleClick事件
    mktime 夏令时
    STL String的使用[转]
    加在电源后至进入操作系统前的计算机的行为
    C语言数据类型大小分析(基于VC2005编译器)
    linux线程同步之条件变量
    windows 下架设svn服务器(转载+修改) (非利用Google项目托管)
    浅尝《Windows核心编程》之内核对象
    C——数组与指针
    如何用U盘做系统启动盘WINPE 并且 利用WINPE安装Ghost
  • 原文地址:https://www.cnblogs.com/TNTZWC/p/1901113.html
Copyright © 2011-2022 走看看