GridView 若需要有滚动条,通常会将 GridView 置于 Panel 中,并设定 Panel 的 ScrollBars 属性为 "Auto" 时,这样 Panel 就会自动判断是否需要出现水平或垂直滚动条。
 
1维护 Panel 滚动条位置        <asp:Panel ID="Panel1" runat="server" Height="300px" Width="712px" ScrollBars="Auto" BorderStyle="Solid" BorderWidth="1px">
2维护 Panel 滚动条位置        <asp:GridView ID="GridView1" runat="server" AllowSorting="True" AutoGenerateColumns="False"
3维护 Panel 滚动条位置            DataKeyNames="ProductID" DataSourceID="SqlDataSource1" EmptyDataText="没有数据录可显示。">
4维护 Panel 滚动条位置            <Columns>
5维护 Panel 滚动条位置                ...
6维护 Panel 滚动条位置                ...
7维护 Panel 滚动条位置            </Columns>
8维护 Panel 滚动条位置        </asp:GridView>
9维护 Panel 滚动条位置        </asp:Panel>

可是当页面 PostBack 时,Panel 的垂直滚动条会跳回最上方,水平滚动条会跳回最左方。我们可以参考 Page.MaintainScrollPositionOnPostBack 属性的做法(参考 解析 Page.MaintainScrollPositionOnPostBack 属性 这篇文章),利用二个 HiddenField 来记录水平及垂直滚动条的位置。

我们可以在 Page Load 中撰写如下的程序代码,其中 Panel 的 ID 命名为 Panel1,在面页输出 "ScrollPosX" 及 "ScrollPosY" 二个 HiddenField,当页面 Sumbit 时,利用 "ScrollPosX" HiddenField 来记录滚动条水平位置,"ScrollPosY" HiddenField 来记录垂直位置。而当页面 PostBack 后重新加载页面,就取得这二个 HiddenField 值,重新设定 Panel 的滚动条位置,如此就可以维护 Panel 滚动条位置。

 1End Sub


相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-01-17
  • 2021-12-02
  • 2022-02-10
猜你喜欢
  • 2022-02-17
  • 2021-11-25
  • 2021-07-07
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案