posts - 116,  comments - 34,  trackbacks - 0
  经常有这样的情况,我们需要用户提交一个表单,但是表单中有超过500+个?控件或文本框要填写,也就是说用户需要拉动IE的滚动条才能够填得完,那么假如用户正在可见IE范围的2/3处,选择了一个组合框的值,很不幸组合框是服务器端的,那么也就意味着页面会提交一次,而当用户再看见刷新过的页面时,页面确定在3/1的地方也就是显示在页面最开始的地方,用户只有拖动鼠标,然后接着刚刚的地方再填写剩下的250个控件,很不幸,370个控件又需要他选择一下?
  用下面的方法可以很快地确定和记住你提交前的位置。
  网上的Old Dog Learns New Tricks也有一个类似的例子Maintain Scroll Position in any Page Element,不过他使用了Web Behavior这意味着你需要使用一个.htc文件
Private Sub RetainScrollPosition()
Dim saveScrollPosition As New StringBuilder
Dim setScrollPosition As New StringBuilder

RegisterHiddenField(“__SCROLLPOS”, “0”)
saveScrollPosition.Append(“<script language=’javascript’>”)
saveScrollPosition.Append(“function saveScrollPosition() {“)
saveScrollPosition.Append(“ document.forms[0].__SCROLLPOS.value = thebody.scrollTop;”)
saveScrollPosition.Append(“}”)
saveScrollPosition.Append(“thebody.onscroll=saveScrollPosition;”)
saveScrollPosition.Append(“</script>”)
RegisterStartupScript(“saveScroll”, saveScrollPosition.ToString())
If (Page.IsPostBack = True) Then
setScrollPosition.Append(“<script language=’javascript’>”)
setScrollPosition.Append(“function setScrollPosition() {“)
setScrollPosition.Append(“ thebody.scrollTop = “ & Request(“__SCROLLPOS”) & “;”)
setScrollPosition.Append(“}”)
setScrollPosition.Append(“thebody.onload=setScrollPosition;”)
setScrollPosition.Append(“</script>”)
RegisterStartupScript(“setScroll”, setScrollPosition.ToString())
End If
End Sub

调用时:
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
RetainScrollPosition()
End Sub

posted on 2006-02-21 17:15 萌芽的叶子 阅读(485) 评论(0)  编辑 收藏 引用 所属分类: asp.net
只有注册用户登录后才能发表评论。

<2006年2月>
2930311234
567891011
12131415161718
19202122232425
2627281234
567891011

常用链接

留言簿(3)

随笔分类(115)

随笔档案(116)

文章分类(4)

相册

收藏夹(78)

.net中文社区

.net博客

.net英文社区

AJAX

ASP.NET 2.0

ASP.NET 学习

DataBase

ERP

E杂志

Html&Css

JavaScript

Microsoft

Open Sourse

SAP

WebCasts

WebServices

XML

其他

好友Blog

好文章连接

开发工具

控件

物流

职业经理人

设计模式

读书网站

非技术

项目管理

搜索

  •  

积分与排名

  • 积分 - 58436
  • 排名 - 106

最新评论

阅读排行榜

评论排行榜