• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > 在ASP.NET 2.0中操作数据之四十四:DataList和Repeater数据排序(三)

在ASP.NET 2.0中操作数据之四十四:DataList和Repeater数据排序(三)

作者:heker2007 字体:[增加 减小] 来源:互联网 时间:2017-05-11

heker2007通过本文主要向大家介绍了repeater asp.net,asp:repeater,asp repeater分页,asp:repeater绑定数据,asp:repeater id等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

第七步: 在自定义分页的Repeater 里添加排序功能

  现在已经完成了自定义分页,我们再来添加排序功能。ProductsBLL类的GetProductsPagedAndSorted方法和GetProductsPaged一样有startRowIndex 和 maximumRows 参数,不一样的是它还多了一个sortExpression 参数。在SortingWithCustomPaging.aspx里使用GetProductsPagedAndSorted方法我们需要:

  将ObjectDataSource的SelectMethod属性从GetProductsPaged改为GetProductsPagedAndSorted。
  为ObjectDataSource的SelectParameters参数集合增加一个sortExpression Parameter。
  创建一个私有的属性用来在postback过程中通过view state存储SortExpression。
  修改ObjectDataSource的Selecting event handler将ObjectDataSource的sortExpression 参数值赋为SortExpression 属性(3中创建的)。
  创建排序界面。

  首先修改ObjectDataSource的SelectMethod属性并添加sortExpression 参数。确定sortExpression 的类型是String。完成这些后ObjectDataSource的声明标记看起来应该和下面差不多:

<asp:ObjectDataSource ID="ProductsDataSource" runat="server"
 OldValuesParameterFormatString="original_{0}" TypeName="ProductsBLL"
 SelectMethod="GetProductsPagedAndSorted"
 OnSelecting="ProductsDataSource_Selecting">
 <SelectParameters>
  <asp:Parameter Name="sortExpression" Type="String" />
  <asp:Parameter Name="startRowIndex" Type="Int32" />
  <asp:Parameter Name="maximumRows" Type="Int32" />
 </SelectParameters>
</asp:ObjectDataSource>
</div>

然后添加一个SortExpression属性,它的值为view state。在没有设任何sort expression的值时候,使用“ProductName”作为默认值。

private string SortExpression
{
 get
 {
  object o = ViewState["SortExpression"];
  if (o == null)
   return "ProductName";
  else
   return o.ToString();
 }
 set
 {
  ViewState["SortExpression"] = value;
 }
}
</div>

  在ObjectDataSource调用GetProductsPagedAndSorted方法前,我们需要将sortExpression 参数设为SortExpression属性的值。在Selecting event handler里添加以下代码:

e.InputParameters["sortExpression"] = SortExpression;

</div>

  现在只需要完成排序界面就可以了。和我们上一个例子一样,我们使用3个button来实现排序功能,允许用户根据product name, category, supplier来排序。

<asp:Button runat="server" id="SortByProductName"
 Text="Sort by Product Name" />
<asp:Button runat="server" id="SortByCategoryName"
 Text="Sort by Category" />
<asp:Button runat="server" id="SortBySupplierName"
 Text="Sort by Supplier" />
</div>

  为这三个button都创建Click event handler。在其中将StartRowIndex设为0,SortExpression设为相应的值,并将数据重新绑定到Repeater。

protected void SortByProductName_Click(object sender, EventArgs e)
{
 StartRowIndex = 0;
 SortExpression = "ProductName";
 Products.DataBind();
}
protected void SortByCategoryName_Click(object sender, EventArgs e)
{
 StartRowIndex = 0;
 SortExpression = "CategoryName";
 Products.DataBind();
}
protected void SortBySupplierName_Click(object sender, EventArgs e)
{
 StartRowIndex = 0;
 SortExpression = "CompanyName";
 Products.DataBind();
}
</div>

  现在所有工作都完成了!实现自定义分页和排序的一些步骤和默认分页差不多。图18显示的当按照category排序时的最后一页数据。

http://files.weikejianghu.com/file_images/article/201605/2016051411324436.png
图 18: 按Category排序的最后一页数据

注意:在前面的例子里,当按照supplier排序时排序表达式为” SupplierName”。然而执行自定义分页时我们需要使用” CompanyName”。这是因为自定义分页的存储过程–GetProductsPagedAndSorted–将sort expression传给ROW_NUMBER(),ROW_NUMBER()需要一个实际的列名,而不是别名。因此我们必须使用CompanyName(Suppliers表的一个列名),而不是使用SupplierName (SELECT语句里的别名)作为expression。

总结

  无论是DataList还是Repeater都没有提供内置的排序支持,但是通过自定义界面和一点点代码,我们可以实现这样的功能。当仅仅只实现排序时(不包含分页),sort expression可以通过DataSourceSelectArguments对象传给ObjectDataSource的Select方法。DataSourceSelectArguments对象的SortExpression属性可以在ObjectDataSource的electing event handler里赋值。

  为已经有排序功能的DataList或Repeater添加排序功能,最简单的方法是在BLL里添加一个接收sort expression的方法。然后这个信息可以通过ObjectDataSource的SelectParameters参数传进去。

  祝编程快乐!

作者简介

  本系列教程作者 Scott Mitchell,著有六本ASP/ASP.NET方面的书,是4GuysFromRolla.com的创始人,自1998年以来一直应用 微软Web技术。大家可以点击查看全部教程《[翻译]Scott Mitchell 的ASP.NET 2.0数据教程》,希望对大家的学习ASP.NET有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • .NET中的repeater简介及分页效果
  • 详解ASP.NET数据绑定操作中Repeater控件的用法
  • 在ASP.NET 2.0中操作数据之四十四:DataList和Repeater数据排序(三)
  • 在ASP.NET 2.0中操作数据之四十三:DataList和Repeater数据排序(二)
  • 在ASP.NET 2.0中操作数据之四十二:DataList和Repeater数据排序(一)
  • 在ASP.NET 2.0中操作数据之四十一:DataList和Repeater数据分页
  • 在ASP.NET 2.0中操作数据之三十:格式化DataList和Repeater的数据
  • 在ASP.NET 2.0中操作数据之二十九:用DataList和Repeater来显示数据
  • asp.net实现DataList与Repeater嵌套绑定的方法
  • ASP.NET数据绑定之Repeater控件

相关文章

  • 2017-05-11sealed在C#中的作用说明
  • 2017-05-11asp.net access添加返回自递增id的实现方法第1/3页
  • 2017-05-11ASP.NET之自定义同步HTTP处理程序(图文教程)
  • 2017-05-11DropDownList 下拉框选择改变促发事件和防全局刷新(推荐)
  • 2018-08-20ASP.NET MVC 使用Bootstrap的方法
  • 2017-05-11.net泛型通用函数的特殊问题的解决方法
  • 2017-05-11asp.net 文章分页显示实现代码
  • 2017-05-11ADO.NET编程之基础知识
  • 2017-05-11Server.Transfer,Response.Redirect的区别
  • 2017-05-11Asp.net SignalR支持的平台有哪些

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C# 文件上传 默认最大为4M的解决方法
    • AJAX使用post发送数据xml格式接受数据
    • .net实现oracle数据库中获取新插入数据的id的方法
    • ASP.NET中URL Routing和IIS上URL Rewriting的区别
    • 一步步做自己的webinstall安装包
    • Asp.net禁用页面缓存的方法总结
    • .NET Core 2.0迁移小技巧之web.config 配置文件示例详解
    • 解析WPF实现音频文件循环顺序播放的解决方法
    • c# 操作符?? null coalescing operator
    • asp.net 读取配置文件方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有