保存div与页面滚动条的位置

本文介绍了一种在ASP.NET Web应用程序中保存页面和特定div元素滚动位置的方法。通过在页面加载和滚动时注册JavaScript函数,可以记录并恢复滚动位置。此技术有助于提升用户体验,特别是在用户需要滚动查看页面内容的应用场景中。
1 ExpandedBlockStart.gif ContractedBlock.gif /**/ /// <summary>
2InBlock.gif/// 保存div与页面滚动条的位置
3InBlock.gif /// </summary>
9ExpandedBlockEnd.gif/// <param name="divId">DIV的ID数组</param>
10 None.gif public static void RetainScrollPosition( string[] divId)
11 ExpandedBlockStart.gif ContractedBlock.gif dot.gif {
12InBlock.gif
13InBlock.gif System.Web.UI.Page page=(Page)HttpContext.Current.Handler;
14InBlock.gif
15InBlock.gifstring saveScrollPosition = "";
16InBlock.gifstring setScrollPosition = "";
17InBlock.gif
18InBlock.gifstring saveScrollPositionDiv = "";
19InBlock.gifstring setScrollPositionDiv = "";
20InBlock.gif
21ContractedSubBlock.gifExpandedSubBlockStart.gif保存页面滚动条的状态#region 保存页面滚动条的状态
22InBlock.gif page.RegisterHiddenField("__SCROLLPOS_TOP","0");
23InBlock.gif page.RegisterHiddenField("__SCROLLPOS_LEFT","0");
24InBlock.gif
25InBlock.gif saveScrollPosition = "document.forms[0].__SCROLLPOS_TOP.value = {0}.scrollTop;document.forms[0].__SCROLLPOS_LEFT.value = {0}.scrollLeft;";//}{0}.onscroll=saveScrollPosition;</script>";
26InBlock.gif setScrollPosition = "{0}.scrollTop ='{1}';{0}.scrollLeft ='{2}';";//}{0}.onload=setScrollPosition;</script>";
27InBlock.gif
28InBlock.gif saveScrollPosition = string.Format(saveScrollPosition,"window.document.body");
29InBlock.gif setScrollPosition = string.Format(setScrollPosition,"window.document.body", page.Request.Form["__SCROLLPOS_TOP"],page.Request.Form["__SCROLLPOS_LEFT"]);
30ExpandedSubBlockEnd.gif#endregion
31InBlock.gif
32ContractedSubBlock.gifExpandedSubBlockStart.gif保存divId的位置#region 保存divId的位置
33InBlock.giffor (int i = 0; i < divId.Length; i++)
34ExpandedSubBlockStart.gifContractedSubBlock.gifdot.gif{
35InBlock.gif page.RegisterHiddenField(divId[i].ToString() + "_TOP","0");
36InBlock.gif page.RegisterHiddenField(divId[i].ToString() + "_LEFT","0");
37InBlock.gif
38InBlock.gif saveScrollPositionDiv = "<script language='javascript'>function saveScrollPosition" + divId[i].ToString() + "() {{document.all('" + divId[i].ToString() + "_TOP').value = {0}.scrollTop;document.all('" + divId[i].ToString() + "_LEFT').value = {0}.scrollLeft;}}{0}.onscroll=saveScrollPosition" + divId[i].ToString() + ";</script>";
39InBlock.gif setScrollPositionDiv += "{0}.scrollTop = {1};{0}.scrollLeft = {2};";
40InBlock.gif
41InBlock.gif saveScrollPositionDiv = string.Format(saveScrollPositionDiv,"window.document.all('" + divId[i].ToString() + "')");
42InBlock.gif page.RegisterStartupScript("saveScroll" + divId[i].ToString(), saveScrollPositionDiv);
43InBlock.gif
44InBlock.gif setScrollPositionDiv = string.Format(setScrollPositionDiv,"window.document.all('" + divId[i].ToString() + "')", page.Request.Form[divId[i].ToString() + "_TOP"],page.Request.Form[divId[i].ToString() + "_LEFT"]);
45ExpandedSubBlockEnd.gif }
46ExpandedSubBlockEnd.gif#endregion
47InBlock.gif
48ContractedSubBlock.gifExpandedSubBlockStart.gif注册客户端脚本#region 注册客户端脚本
49InBlock.gif saveScrollPosition = "<script language='javascript'>function saveScrollPosition() {{" + saveScrollPosition + "}}{0}.onscroll=saveScrollPosition;</script>";
50InBlock.gif page.RegisterStartupScript("saveScroll", string.Format(saveScrollPosition,"window.document.body"));
51InBlock.gif
52InBlock.gifif(page.IsPostBack)
53ExpandedSubBlockStart.gifContractedSubBlock.gifdot.gif{
54InBlock.gif setScrollPosition = "<script language='javascript'>function setScrollPosition() {{" + setScrollPosition + setScrollPositionDiv + "}}{0}.onload=setScrollPosition;</script>";
55InBlock.gif page.RegisterStartupScript("setScroll", string.Format(setScrollPosition,"window.document.body"));
56InBlock.gif//page.RegisterStartupScript("setScrollDocument", string.Format(setScrollPosition,"window.document.body", page.Request.Form["__SCROLLPOS_TOP"],page.Request.Form["__SCROLLPOS_LEFT"]));
57ExpandedSubBlockEnd.gif }
58ExpandedSubBlockEnd.gif#endregion
59InBlock.gif
60ExpandedBlockEnd.gif }



本文转自高海东博客园博客,原文链接:http://www.cnblogs.com/ghd258/archive/2005/11/07/270441.html,如需转载请自行联系原作者
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值