在 ASP.NET 上实现锁定表头、支持滚动的表格的做法

本文介绍在ASP.NET平台上实现支持双向滚动、锁定表头的表格组件的方法。通过使用CSS、Panel控件和GridView控件,结合Atlas技术,确保表格在页面PostBack时能保持滚动位置。
 

首先看看 CodeProject 上的两个东西

1、The Freeze Pane DataGridhttp://www.codeproject.com/aspnet/FreezePaneDatagrid.asp

利用文章中提到做法及代码,可以实现在 ASP.NET 1.1 上的、支持横向滚动与纵向滚动的表格,基本上是使用 CSS 实现的,比较简单。

在 ASP.NET 2.0 上,由于文档 HTML DOCKTYPE 发生了变化(HTML->XHTML),所以在使用原文中的横向滚动条会出现问题,但是使用纵向滚动条和锁定表头没有问题。

这种做法没有考虑页面 PostBack 时记录表格的滚动位置,使得用户不得不重新去寻找刚才选中/编辑的那条记录,这比较的不人性化。

2、ScrollingGrid: A cross-browser freeze-header two-way scrolling DataGridhttp://www.codeproject.com/aspnet/ScrollingGrid.asp

此文章利用 Panel 控件和 DataGrid 控件实现了 ASP.NET 1.1 下的完整的、可实现双向滚动、表头锁定的表格,而且它实现了可以记录表格的滚动位置,页面 PostBack 后,表格仍能自动滚动到原有位置。这个控件的一个最大优点是能够适应多种浏览器,如 Internet Explorer 、FireFox 等。

在 ASP.NET 平台上,由于 DataGrid 控件已经升级为 GridView ,所以此控件已不能使用,按照文章下面的讨论,作者声称会尽快升级控件,但似乎在实现时碰到一些麻烦(如何确实表头各列的宽度),目前还没有结果。

目前我的做法:

  1. 参照文章1中提到的作法,利用 CSS 来实现锁定表头的功能
  2. 利用 Panel 控件,设置 ScrollBar 为 Vertical,再在其中放入 GridView 控件 ,可以实现竖向滚动条的功能
  3. 利用 Atlas ,将上述 Panel 再放入 UpdatePanel ,以透明实现保持滚动条位置的功能

示例代码:


  
None.gif < h1 > 滚动条表格演示h1> ExpandedBlockStart.gifContractedBlock.gif < style type ="text/css" > ... ... ExpandedSubBlockStart.gifContractedSubBlock.gifth {...}{...}{...}{ InBlock.gifborder-right: 1px solid silver; InBlock.gifposition:relative; ExpandedSubBlockStart.gifContractedSubBlock.giftop: expression(this.parentNode.parentNode.parentNode.parentNode.parentNode.parentNode.scrollTop-2); /**//**//**//*IE5+ only*/ ExpandedSubBlockEnd.gif} InBlock.gifstyle> InBlock.gifInBlock.gif<atlas:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="True"> InBlock.gifatlas:ScriptManager> InBlock.gif<br /> InBlock.gif<asp:Panel ID="GridPanel" runat="server" Height="250px" ScrollBars="Auto" Width="562px"> InBlock.gif <atlas:UpdatePanel ID="UpdatePanel1" runat="server"> InBlock.gif <ContentTemplate> InBlock.gif <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataSourceID="ObjectDataSource1" SkinID="GridView" Width="434px"> InBlock.gif </asp:GridView> InBlock.gif </ContentTemplate> InBlock.gif </atlas:UpdatePanel> InBlock.gif</asp:Panel>

这样能基本上实现一个能够锁定表头、竖向滚动、能够在页面PostBack时保持滚动位置的表格,能够满足大部分应用需要。

转载于:https://www.cnblogs.com/wenrenhua08/archive/2008/09/24/3993635.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值