维护Panel的滚动条ScrollBars位置(C#)

本文介绍如何在ASP.NET中使用Panel控件时,保持PostBack后的滚动条位置不变。通过两个HiddenField记录滚动位置,并利用JavaScript实现PostBack前后滚动条位置的同步。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  我们常将内容放在Panel中,例如文章,GridView控件等....。当内容超出Panel的高、宽时,可能就需要滚动条来进行控制。 当点击页面中按钮产生PostBack时,滚动条总是会回到最上面的位置,我们现在要解决的主要就是这个问题。

ScrollBar的可选项有:

 

成员名称

说明

 

Auto

根据需要,可显示水平滚动条、垂直滚动条或这两种滚动条。要不然也可以不显示任何滚动条。 

 

Both

同时显示水平滚动条和垂直滚动条。 

 

Horizontal

只显示水平滚动条。 

 

None

不显示滚动条。 

 

Vertical

只显示垂直滚动条。 

演示如何控制ScrollBars的Demo,基本思路是通过两个HiddenField在Submit时纪录下Panel的scrollLeft,scrollTop的值,当IsPostBack时,当两个HiddenField的value重新设置给Panel的scrollLeft,scrllTop.

Html代码

 在页面中放两个Panel,一个做为容器,一个做为内容(只为演示作用)。

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="ControlPanelScrollBarSample.aspx.cs" Inherits="ControlPanelScrollBarSample" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    
<title>演示如何控制Panel的滚动块</title>
</head>
<body>
    
<form id="form1" runat="server">
    
<div style="text-align:center;">
    
<asp:Panel ID="P_Container" runat="server" ScrollBars="Auto" Width="80%" Height="400px">
    
<asp:Panel ID="P_Content" runat="server" Width="90%">
    
</asp:Panel>
    
</asp:Panel>
        
<br />
        
<asp:Button ID="BT_Submit" runat="server" Text="点击确发PostBack,查看滚动块的位置" />
    
</div>
    
</form>
</body>
</html>

CS代码:

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class ControlPanelScrollBarSample : System.Web.UI.Page
{
    
protected void Page_Load(object sender, EventArgs e)
    
{
            FillContentPanel();
            HandlePanelScrolBar();
    }


    
private void HandlePanelScrolBar()
    
{
        
//定义两个HiddenField,分别纪录Panel的ScrollBar的X与Y位置
        HiddenField HF_ScrollPosX = new HiddenField();
        HiddenField HF_ScrollPosY 
= new HiddenField();

        HF_ScrollPosX.ID 
= "ScrollPosX";
        HF_ScrollPosY.ID 
= "ScrollPosY";
        form1.Controls.Add(HF_ScrollPosX);
        form1.Controls.Add(HF_ScrollPosY);

        
//生成JS:将Panel的ScrollBar的X,Y位置设置给两个HiddenField
        string script;
        script 
= "window.document.getElementById('" + HF_ScrollPosX.ClientID + "').value = "
                  
+ "window.document.getElementById('" + P_Container.ClientID + "').scrollLeft;"
                  
+ "window.document.getElementById('" + HF_ScrollPosY.ClientID + "').value = "
                  
+ "window.document.getElementById('" + P_Container.ClientID + "').scrollTop;";

        
this.ClientScript.RegisterOnSubmitStatement(this.GetType(), "SavePanelScroll", script);

        
if (IsPostBack) //如果是PostBack,将保存在HiddenField的ScrollBar的X,Y值重设回给Panel的ScrollBar
        {
            script 
= "window.document.getElementById('" + P_Container.ClientID + "').scrollLeft = "
                    
+ "window.document.getElementById('" + HF_ScrollPosX.ClientID + "').value;"
                    
+ "window.document.getElementById('" + P_Container.ClientID + "').scrollTop = "
                    
+ "window.document.getElementById('" + HF_ScrollPosY.ClientID + "').value;";

            
this.ClientScript.RegisterStartupScript(this.GetType(), "SetPanelScroll", script, true);
        }

    }

   
    
/// <summary>
    
/// 填充内容数据,视情况可使外Panel产生滚动条即可
    
/// </summary>

    private void FillContentPanel()
    
{
        Literal l 
= new Literal();
        
string context = "";

        
for (int i = 0; i < 100; i++)
        
{
            context 
+= "<BR>" + i + "行  中华人民共和国中华人民共和国!!!";    
        }


        l.Text 
= context;
        P_Content.Controls.Add(l);
    }

}

 补充一点:注意页面中两个Panel,我们要处理的是外面这个Panel,也就是本文中的P_Container,而不是P_Content,我开始就犯了这个错误,如果去获取P_Content的scrollLeft和scrollTop,始终都是0!

 

评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值