软件下载,下载软件,网络软件,软件学院,软件资讯,电子小说,书籍,音乐,游戏,歌曲,MP3,BT,Flash,QQ
设为首页  
联系我们  
加入收藏  
   软件新闻 网络动态 软件评测 信息安全 软件技巧 编程开发 设计教程 教学动画 游戏娱乐
您的位置: 首页 >> 文章首页 >> 编程开发 >> 网络编程 >> ASP.NET 2.0数据处理之高级分页与排序
站内搜索
网络编程TOP10
·ASP.NET 2.0高级数据处理之冲突检测2006-11-28 15:22:13
·XMLHTTP+Javascript+Asp写的聊天室,无刷新实现2006-2-5 16:51:25
·ASP.NET 2.0高级数据处理之冲突检测2006-11-28 15:22:13
·ASP技巧TOP10 (1)2005-11-30 15:55:33
·ASP.NET 2.0服务器控件之客户端功能2006-8-10 9:53:40
·揭开ASP神秘面纱(1)2005-11-7 16:57:11
·XML和JSP的联手2006-1-20 10:20:57
·ASP.NET 2.0服务器控件开发之简单属性2006-6-13 11:00:51
·深入ASP.NET 2.0的提供者模型2006-8-25 11:25:44
·asp.net中用sqlclient访问数据库出错解决办法2005-11-11 14:52:08
编程开发TOP10
·ASP.NET 2.0高级数据处理之冲突检测2006-11-28 15:22:13
·XMLHTTP+Javascript+Asp写的聊天室,无刷新实现2006-2-5 16:51:25
·ASP.NET 2.0高级数据处理之冲突检测2006-11-28 15:22:13
·ASP技巧TOP10 (1)2005-11-30 15:55:33
·道与魔:SqlServer存储过程/函数加/解密2005-11-1 21:35:22
·如何自动发布MS SQL SERVER数据库?2005-11-16 15:43:30
·微软建议的ASP性能优化28条守则二2005-11-9 15:26:02
·深入ASP.NET 2.0的提供者模型2006-8-25 11:25:44
·ASP.NET 2.0服务器控件之客户端功能2006-8-10 9:53:40
·C++Builder动态更改自定义打印纸张2005-11-2 17:13:18
本类精品推荐
精选专题
 
ASP.NET 2.0数据处理之高级分页与排序
作者:陶刚编译 来源:风暴软件站 时间:2006-11-30 15:49:32
 

  GridView控件中的"选择"操作纯粹是一个UI概念,它的SelectedIndex属性与表格的可视数据行中的当前被选中的行的索引相对应。如果你启用了表格的分页和排序功能,在执行分页或排序操作之后,SelectedIndex的值仍然不会变化,因此在执行这些操作之后,一个新数据行被选中了。在某些环境下,保留对指定数据行的选中更好,即使该行在表格的当前页面中并不可视。下面的例子演示了如何在排序和分页操作之后仍然保留当前选中的数据行。

Sub GridView1_DataBound(ByVal sender As Object, ByVal e As System.EventArgs)
 Dim Row As GridViewRow
 Dim SelectedValue As String = ViewState("SelectedValue")
 If SelectedValue Is Nothing Then
  Return
 End If
 ' 检测选择的行是哪个并重新选中它
 For Each Row In GridView1.Rows
  Dim KeyValue As String = GridView1.DataKeys(Row.RowIndex).Value
  If (KeyValue = SelectedValue) Then
   GridView1.SelectedIndex = Row.RowIndex
  End If
 Next
End Sub

Protected Sub GridView1_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs)
 ' 保存选中行的索引
 If (Not GridView1.SelectedIndex = -1) Then
  ViewState("SelectedValue") = GridView1.SelectedValue
 End If
End Sub

Protected Sub GridView1_PageIndexChanging(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewPageEventArgs)
 ' 重置选中索引
 GridView1.SelectedIndex = -1
End Sub

Sub GridView1_Sorting(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewSortEventArgs)
 ' 重置选择索引
 GridView1.SelectedIndex = -1
End Sub

  GridView和DetailsView还支持一种用于分页和排序的特殊模式,它利用客户端向服务器的回调(callback)操作来获取新页面的数据或最近排序过的数据。要激活这个特性,必须把EnableSortingAndPagingCallbacks属性设置为真。请注意,当我们执行分页或排序操作的时候,页面不需要发回(postback)以检索新值(尽管执行了客户端脚本向服务器的回调操作)。当GridView或DetailsView包含模板字段的时候是不支持这个特性的。当这个特性被激活的时候,不支持在CommandField(命令字段)中显示"选择"按钮。

<asp:GridView AllowPaging="True" AllowSorting="True" AutoGenerateColumns="False" DataKeyNames="au_id" DataSourceID="SqlDataSource1" EnableSortingAndPagingCallbacks="True" ID="GridView1" runat="server">
……
</asp:GridView>

  尽管GridView、DetailsView和FormView为分页器(pager)UI提供了默认的显示方式,你仍然可以通过设置PagerTemplate属性来自定义分页器的显示。在这个模板中,你可以放置按钮控件,并把它的CommandName属性设置为Page,把它的属性设置为First、Prev、Next、Last或<number>,其中<number>是特定页面的索引值。下面的例子演示了GridView和DetailsView控件定义的PagerTemplate。

<PagerTemplate>
<asp:LinkButton CommandName="Page" CommandArgument="First" ID="LinkButton1" runat="server" Style="color: white"><< First</asp:LinkButton>
<asp:LinkButton CommandName="Page" CommandArgument="Prev" ID="LinkButton2" runat="server" Style="color: white">< Prev</asp:LinkButton>
[Records <%= GridView1.PageIndex * GridView1.PageSize %> - <%= GridView1.PageIndex * GridView1.PageSize + GridView1.PageSize - 1 %>]
<asp:LinkButton CommandName="Page" CommandArgument="Next" ID="LinkButton3" runat="server" Style="color: white">Next ></asp:LinkButton>
<asp:LinkButton CommandName="Page" CommandArgument="Last" ID="LinkButton4" runat="server" Style="color: white">Last >></asp:LinkButton>
</PagerTemplate>

 
 
 
相关文章:
相关软件: