ASP.NET MVC中对数据进行排序的方法

为此,我们添加一个新类,这些类被称为特定视图服务的模型,打开上一篇文章中已经实现的应用程序,在Models文件夹下添加一个名为ProductGridModel.cs 的文件,代码如下:

namespaceWeb.Models

{

public classProductGridModel

{

// Data properties      public IEnumerable Product Products { get; set; }

// Sorting-related properties      public string SortBy { get; set; }

public bool SortAscending { get; set; }

public stringSortExpression

{

get

{

return this.SortAscending ? this.SortBy + " asc" : this.SortBy + " desc";

}

}

}

}

  该ProductGridModel类定义了一个产品属性,它是一个集合类的属性,用来显示产品集合,同时也有三种排序相关的属性:

  SortBy

  在数据库中用来排序的数据列名称

  SortAscending

  一个布尔值,指示是否用升序排序数据

  SortExpression

  只读属性,返回一个排序字符串,其构造为SortBy和SortAscending值的组合。

  例如,如果SortBy分为UnitePrice和SortAscending是true,SortExpression的值为

   UnitedPrice asc。

  如果SortBy设置为Discontinued 和SortAscending是false,则SortExpression返回Discontinued desc 。

  步骤2:创建Sortable 的Action方法

  在上一篇教程中,我们创建了一个名为ProductsController的控制器,其中有一个叫index的action和一个辅助属性DataContext,本文中,我们将添加一个新的action方法到控制器中,并命名为Sortable,当有来自如www.yoursite.com/Products/Sortable的请求时,则执行该排序方法。

  ASP.NET MVC中实现了自动参数绑定,来自URL或其他的参数请求,将被映射到执行的实际的action中去。例如,如果你在控制器action中定义了一个输入参数,名为sortBy,则MVC框架将搜索传入的请求的参数,看是否有任何具有相同名称的参数(在这里,一个参数可能是一个提交表单域,一个查询字符串参数或路由参数。)如果找到一个匹配,则自动把参数的值得赋给action中定义的参数。

  下面是其实际代码:

public classProductsController : Controller

{

...

// GET: /Products/Sortable?SortColumn=columnNameAscending=true|falsepublic ActionResult Sortable(string sortBy = "ProductName", bool ascending = true)

{

var model

= newProductGridModel()

{

SortBy

=sortBy,

SortAscending

=ascending

};

model.Products

= this.DataContext.Products.OrderBy(model.SortExpression);

returnView(model);

}

}

  请注意,action中接受两个输入参数:sortBy和ascending。任何来自URL的请求,只要符合这两个参数的名称的,其值得都会被自动匹配传入到该action中去, 也就是说,如果有人访问www.yoursite.com不指定查询字符串参数,则默认按照产品的名称进行升序排序。

  Sortable的action首先创建一个新的ProductGridModel实例,命名为model,并且对model的SortBy和SortAscending属性进行赋值,接着,Sortable action获得了产品的集合(this.DataContext.Products),并调用其中的OrderBy方法进行排序,而排序的参数表达式正好是SortExpression。最后,将model模型返回给一个强类型的视图,。

  如果您熟悉使用LINQ,你会觉得我在这里使用的OrderBy方法有点奇怪,你可能会用LINQ中的lambda表达式如下这样写,如:this.DataContext.Products.OrderBy(p =p.ProductName)。

  OrderBy方法,我使用的是不标准的LINQ,相反是微软的动态LINQ库中的方法

(http://weblogs.asp.net/scottgu/archive/2008/01/07/dynamic-linq-part-1-using-the-linq-dynamic-query-library.aspx),它是一个库允许使用字符串做为查询参数。本文附件中提供了一个名为Dynamic.cs的文件(它在HelperClasses文件夹中),其中包含了OrderBy扩展方法签名,大家可以去学习一下。 

龙华大道1号http://www.kinghill.cn/LongHuaDaDao1Hao/index.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。