一、能够使用MvcPager进行分页
一、MvcPager控件的简单使用
二、C#扩展方法
1、添加MvcPager.dll的引用[下载]
2、Control中的方法
1 //获取列表 2 public ActionResult List(int? id = 1) 3 { 4 List<DTO.User> userList = new List<DTO.User>(); 5 int totalCount = 0; 6 int pageIndex = id ?? 1; 7 userList = SC.Repository.User.GetList("", 2, (pageIndex - 1) * 2, out totalCount); 8 PagedList<DTO.User> mPage = userList.AsQueryable().ToPagedList(pageIndex, 2); 9 mPage.TotalItemCount = totalCount; 10 mPage.CurrentPageIndex = (int)(id ?? 1); 11 return View(mPage); 12 }
SC.Repository.User.GetList("", 2, (pageIndex - 1) * 2, out totalCount)方法为分页方法,此处的StrUserName只是在查询的时候一个条件而发,其他和传统的分页一样如下:
1 public static List<DTO.User> GetList(string StrUserName, int PageSize, int CurrentCount, out int TotalCount)
PagedList<DTO.User> mPage = userList.AsQueryable().ToPagedList(pageIndex, 2);
这里用到了扩展方法,首先将userList调用Linq中的扩展IEnumerable接口的方法,把List<T>转换成为IQueryable<T>,接口如下:
1 public static IQueryable<TElement> AsQueryable<TElement>(this IEnumerable<TElement> source);
再调用MvcPager中对IQueryable<T>的扩展方法转换成PagedList<T>供View中使用,接口如下:
1 public static PagedList<T> ToPagedList<T>(this IQueryable<T> allItems, int pageIndex, int pageSize);
3、View中使用MvcPager
1 @model PagedList<SongCai8.DTO.User> 2 @using Webdiyer.WebControls.Mvc; 3 @{ 4 Layout = null; 5 } 6 <!DOCTYPE html> 7 <html> 8 <head> 9 <title>List</title> 10 </head> 11 <body> 12 @foreach (SongCai8.DTO.User user in Model) 13 { 14 @user.UserID<span>---</span>@user.UserName<span>---</span> 15 @Html.ActionLink("Edit", "Edit", new { id = user.UserID }) <span>---</span> 16 @Html.ActionLink("Details", "Details", new { id = user.UserID }) <span>---</span> 17 @Html.ActionLink("Delete", "Delete", new { id = user.UserID })<span>---</span> 18 19 <br /> 20 } 21 <br /> 22 <br /> 23 @Html.Pager(Model, new PagerOptions 24 { 25 PageIndexParameterName = "id", 26 ShowPageIndexBox = true, 27 FirstPageText = "首页", 28 PrevPageText = "上一页", 29 NextPageText = "下一页", 30 LastPageText = "末页", 31 PageIndexBoxType = PageIndexBoxType.TextBox, 32 PageIndexBoxWrapperFormatString = "请输入页数{0}", 33 GoButtonText = "转到" 34 }) 35 <br /> 36 >>分页 共有 @Model.TotalItemCount 篇留言 @Model.CurrentPageIndex/@Model.TotalPageCount 37 </body> 38 </html>
4、效果如下:
理解什么是扩展方法:用静态类及静态方法为原有类的添加新的方法。说起来有点抽象,边上代码边解释。
原始类:
1 public class Person 2 { 3 public string ShowName() 4 { 5 return "显示名称"; 6 } 7 }
我们定义了一个Person类,类里只有一个方法ShowName()。众所周知,代码如下:
1 Person person = new Person(); 2 person.ShowName();
扩展类:
加入“显示密码的”扩展方法(为了体现出对比性,下面代码稍有重复):
1 //原始类 2 public class Person 3 { 4 public string ShowName() 5 { 6 return "显示名称"; 7 } 8 } 9 10 //扩展Person的静态类 11 public static class ExtensionMethod 12 { 13 public static string ShowPassword(this Person person) 14 { 15 return "显示密码"; 16 } 17 }
代码解释:
ExtensionMethod中的ShowPassword参数this Person 说明要扩展的类型为Person类,并且要用this关键字修饰。在使用时这个参数是不需要传入的,这点和我们在传统的类中方法参数有些不同。
使用:
使用与平时我们使用在类中定义的方法相同,代码如下:
1 Person person = new Person(); 2 //原始方法 3 Response.Write(person.ShowName()); 4 //换行 5 Response.Write("<br />"); 6 //扩展方法 7 Response.Write(person.ShowPassword());
效果如下:
应用:
最常见的扩展方法是添加查询功能添加到现有 System.Collections.IEnumerable 和 System.Collections.Generic.IEnumerable<T> 类型的 LINQ 标准查询运算符。若要使用标准查询运算符,请首先将它们输入与 using System.Linq 名称空间。 然后,任何实现了 IEnumerable<T> 的类型看起来都具有 GroupBy、OrderBy、Average 等实例方法。 在 IEnumerable<T> 类型的实例(如 List<T> 或 Array)后键入“dot”时,可以在 IntelliSense 语句完成中看到这些附加方法。
详细请查阅MSDN:http://msdn.microsoft.com/zh-cn/library/bb383977.aspx
转载自:http://www.cnblogs.com/iamlilinfeng/archive/2013/03/11/2951460.html
========================================================================
用自己写的分页存储过程,结合MVCPANGER分布控件进行分页
注:PagedList<Maticsoft.Model.guestbook> mvcPageList = lists.AsQueryable().ToPagedList(1, 3); 这句,第一个参数是1,因为进行自已写的分页函数后,已分布后,不需要使用到将全部数据取出再分页那种形式,所以的他一直默认取1
Maticsoft.BLL.guestbook gb = new Maticsoft.BLL.guestbook(); public ActionResult Index(int pageIndex = 1) { //获取页大小 int PageCount = DbHelperSQL.GetSplitPageCount("guestbook", "1=1"); //根据参数 获取分页List数据 List<Maticsoft.Model.guestbook> lists = gb.DataTableToList(DbHelperSQL.GetSplitPageList("guestbook", "*", "id", "desc", 3, pageIndex, "1=1")); //转换成mvcPager控件的List的类型 PagedList<Maticsoft.Model.guestbook> mvcPageList = lists.AsQueryable().ToPagedList(1, 3); mvcPageList.TotalItemCount = PageCount; mvcPageList.CurrentPageIndex = pageIndex; return View(mvcPageList); }
View视图的内容显示
1.需先引有类和设置model
@using Webdiyer.WebControls.Mvc;
@model PagedList<Maticsoft.Model.guestbook>
<div> @foreach (Maticsoft.Model.guestbook item in Model) { Response.Write(item.names + ":" + item.contents + "<a href='/GuestBook/Delete/?id=" + item.id + "'>delete</a>"); Response.Write("<hr/>"); } </div> <div class="clear"> @Html.Pager(Model, new PagerOptions { PageIndexParameterName = "pageIndex", ShowPageIndexBox = true, FirstPageText = "首页", PrevPageText = "上一页", NextPageText = "下一页", LastPageText = "末页", PageIndexBoxType = PageIndexBoxType.TextBox, PageIndexBoxWrapperFormatString = "请输入页数{0}", GoButtonText = "转到" }) </div>