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

该博客提供了保存div与页面滚动条位置的代码实现。通过定义RetainScrollPosition方法,分别保存页面滚动条和div的滚动状态,利用隐藏字段存储位置信息,并注册客户端脚本在页面滚动和加载时进行位置的保存与恢复。
1ExpandedBlockStart.gifContractedBlock.gif/**//// <summary>
 2InBlock.gif        /// 保存div与页面滚动条的位置
 3InBlock.gif        /// </summary>
 9ExpandedBlockEnd.gif        /// <param name="divId">DIV的ID数组</param>

10None.gif        public static void RetainScrollPosition(string[] divId)
11ExpandedBlockStart.gifContractedBlock.gif        dot.gif{
12InBlock.gif            
13InBlock.gif            System.Web.UI.Page page=(Page)HttpContext.Current.Handler;
14InBlock.gif
15InBlock.gif            string saveScrollPosition = "";
16InBlock.gif            string setScrollPosition = "";
17InBlock.gif
18InBlock.gif            string saveScrollPositionDiv = "";
19InBlock.gif            string 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.gif            for (int i = 0; i < divId.Length; i++)
34ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.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.gif            if(page.IsPostBack)
53ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.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        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值