华域联盟 .Net Asp.net保持页面滚动条位置(页面提交后不变)

Asp.net保持页面滚动条位置(页面提交后不变)

一般来说很多的人在控制浏览器滚动条都是用Page.SmartNavigation = False,对于页面中DIV等等的滚动条控制,我在看了别人代码后,写了一个,仅供参考:

复制代码 代码如下:

Public Shared Sub SaveDivScrollPosition(ByVal divIDArray As String, ByVal objPage As Page)

Dim saveScrollPosition As String

Dim i As Integer

Dim divID() As String

divID = divIDArray.Split(",")

For i = 0 To divID.Length - 1

objPage.RegisterHiddenField(divID(i) & "__SCROLLPOS", objPage.Request.Form(divID(i) & "__SCROLLPOS"))

saveScrollPosition = "<script language='javascript'>" _

& "function saveScrollPosition() {" _

& " if (document.all['" & divID(i) & "'] != undefined) {" _

& "document.forms[0]." & divID(i) & "__SCROLLPOS.value = " _

& "document.all['" & divID(i) & "'].scrollTop + ',' " _

& " + document.all['" & divID(i) & "'].scrollLeft;}}" _

& "if (document.all['" & divID(i) & "'] != undefined) {document.all['" & divID(i) & "'].onscroll=saveScrollPosition;}" _

& "</script>"

objPage.RegisterStartupScript("saveScroll" & divID(i), saveScrollPosition)

Next

End Sub

复制代码 代码如下:

Public Shared Sub RestoreDivScrollPosition(ByVal divIDArray As String, ByVal objPage As Page)

Dim restoreScrollPosition As String

Dim setPositionFunction As String

Dim i As Integer

Dim divID() As String

divID = divIDArray.Split(",")

For i = 0 To divID.Length - 1

setPositionFunction = setPositionFunction & "SetScrollPosition('" & divID(i) & "');"

Next

restoreScrollPosition = "<script language='javascript'>" _

& setPositionFunction _

& "</script>"

objPage.RegisterStartupScript("restoreScroll", restoreScrollPosition)

End Sub

JAVASCRIPT:

复制代码 代码如下:

function SetScrollPosition(divID){

var e;

var a;

var obj;

if (document.getElementById(divID)){

obj = eval('document.forms[0].' + divID + '__SCROLLPOS');

if (obj) {

e=eval('document.forms[0].' + divID + '__SCROLLPOS').value;

a=e.split(',');

document.getElementById(divID).scrollTop= a[0];

document.getElementById(divID).scrollLeft= a[1];

}

}

}

在页面后台调用的时候,写下如下的代码:

复制代码 代码如下:

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

call SaveDivScrollPosition("div1,div2,div3",me)

call RestoreDivScrollPosition("div1,div2,div3",me)

End Sub

不好意思,这两个SUB可以写成一个,仅供参考。

您可能感兴趣的文章:

  • asp.net通过Ajax UpdatePanel回传后滚动条位置变更解决方法
  • 解决ASP.NET回传后div滚动条位置复位的问题(利用隐藏控件原理)
  • ASP.Net刷新页面后自动滚动到原来位置方法汇总

本文由 华域联盟 原创撰写:华域联盟 » Asp.net保持页面滚动条位置(页面提交后不变)

转载请保留出处和原文链接:https://www.cnhackhy.com/48812.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部