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
<!--
3
theForm.oldSubmit = theForm.submit;
4
theForm.submit = WebForm_SaveScrollPositionSubmit;
5
6
theForm.oldOnSubmit = theForm.onsubmit;
7
theForm.onsubmit = WebForm_SaveScrollPositionOnSubmit;
8
9
theForm.oldOnLoad = window.onload;
10
window.onload = WebForm_RestoreScrollPosition;
11
// -->
12
</script>
当页面Submit 时会利用WebForm_SaveScrollPositionSubmit
函式来记录页面目前的水平及垂直滚动条位置,将水平滚动条位置记录于"__SCROLLPOSITIONX"
这个 HiddenField,垂直滚动条位置记录于"__SCROLLPOSITIONY"
这个 HiddenField。
而 PostBack 后页面重新加载后,会利用WebForm_RestoreScrollPosition
函式来回复页面滚动条位置,也就是将记录在"__SCROLLPOSITIONX" 及"__SCROLLPOSITIONY" 这二个 HiddenField
的值,重新设定页面的水平及垂直滚动条位置,如此就达到维护页面滚动条位置的动作了。
posted on 2008-01-17 07:23
jeff377 阅读(1020)
评论(1) 编辑 收藏 网摘 所属分类:
ASP.NET 基础