为此,我们添加一个新类,这些类被称为特定视图服务的模型,打开上一篇文章中已经实现的应用程序,在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