详解一个ASP.NET MVC分页效果
创始人
2024-06-21 21:41:15
0

在这里我们将谈到的是ASP.NET MVC框架中的一个HTML辅助类,希望通过本文能对大家了解ASP.NET MVC分页有所帮助。

#T#

本人写的一个ASP.NET MVC分页Helper,支持普通分页(也就是,首页、上一页、下一页、末页等),综合分页(普通分页和数字分页的综合)。下面是ASP.NET MVC分页效果:

LIST分页

分页代码:

PagerHelper.cs

-->  1 using System;
  2 using System.Collections.Generic;
  3 using System.Collections.Specialized;
  4 using System.Linq;
  5 using System.Web;
  6 using System.Text;
  7 using System.Web.Mvc;
  8 using System.Web.Routing;
  9 using System.Data.Objects.DataClasses;
 10 namespace System.Web.Mvc
 11 {
 12     public static class PagerHelper
 13     {
 14         /// 


 15         /// 分页
 16         /// 
 17         /// 
 18         /// 分页id
 19         /// 当前页
 20         /// 分页尺寸
 21         /// 记录总数
 22         /// 分页头标签属性
 23         /// 分页样式
 24         /// 分页模式
 25         /// 
 26         public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, 

  int pageSize, int recordCount, object htmlAttributes, string className,PageMode mode)
 27         {
 28             TagBuilder builder = new TagBuilder("table");
 29             builder.IdAttributeDotReplacement = "_";
 30             builder.GenerateId(id);
 31             builder.AddCssClass(className);
 32             builder.MergeAttributes(new RouteValueDictionary(htmlAttributes));
 33             builder.InnerHtml = GetNormalPage(currentPageIndex, pageSize, recordCount,mode);
 34             return builder.ToString();
 35         }
 36         /// 
 37         /// 分页
 38         /// 
 39         /// 
 40         /// 分页id
 41         /// 当前页
 42         /// 分页尺寸
 43         /// 记录总数
 44         /// 分页样式
 45         /// 
 46         public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, int pageSize, int recordCount, string className)
 47         {
 48             return Pager(helper, id, currentPageIndex, pageSize, recordCount, null, className,PageMode.Normal);
 49         }
 50         /// 
 51         /// 分页
 52         /// 
 53         /// 
 54         /// 分页id
 55         /// 当前页
 56         /// 分页尺寸
 57         /// 记录总数
 58         /// 
 59         public static string Pager(this HtmlHelper helper,string id,int currentPageIndex,int pageSize,int recordCount)
 60         {
 61             return Pager(helper, id, currentPageIndex, pageSize, recordCount,null);
 62         }
 63         /// 
 64         /// 分页
 65         /// 
 66         /// 
 67         /// 分页id
 68         /// 当前页
 69         /// 分页尺寸
 70         /// 记录总数
 71         /// 分页模式
 72         /// 
 73         public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, int pageSize, int recordCount,PageMode mode)
 74         {
 75             return Pager(helper, id, currentPageIndex, pageSize, recordCount, null,mode);
 76         }
 77         /// 
 78         /// 分页
 79         /// 
 80         /// 
 81         /// 分页id
 82         /// 当前页
 83         /// 分页尺寸
 84         /// 记录总数
 85         /// 分页样式
 86         /// 分页模式
 87         /// 
 88         public static string Pager(this HtmlHelper helper, string id, i nt currentPageIndex, int pageSize, int recordCount,string className, PageMode mode)
 89         {
 90             return Pager(helper, id, currentPageIndex, pageSize, recordCount, null,className,mode);
 91         }
 92         /// 
 93         /// 获取普通分页
 94         /// 
 95         /// 
 96         /// 
 97         /// 
 98         /// 
 99         private static string GetNormalPage(int currentPageIndex, int pageSize, int recordCount,PageMode mode)
100         {
101             int pageCount = (recordCount%pageSize ==0?recordCount/pageSize:recordCount/pageSize+1);
102             StringBuilder url = new StringBuilder();
103             url.Append(HttpContext.Current.Request.Url.AbsolutePath+"?page={0}");
104             NameValueCollection collection = HttpContext.Current.Request.QueryString;
105             string[] keys = collection.AllKeys;
106             for (int i = 0; i < keys.Length; i++)
107             {
108                 if (keys[i].ToLower() != "page")
109                     url.AppendFormat("&{0}={1}", keys[i], collection[keys[i]]);
110             }
111             StringBuilder sb = new StringBuilder();
112             sb.Append("     ");
113             sb.AppendFormat("总共{0}条记录,共{1}页,当前第{2}页  ", recordCount, pageCount, currentPageIndex);
114             if (currentPageIndex == 1)
115                 sb.Append("首页 ");
116             else
117             {
118                 string url1 = string.Format(url.ToString(), 1);
119                 sb.AppendFormat("首页 ", url1);
120             }
121             if (currentPageIndex > 1)
122             {
123                 string url1 = string.Format(url.ToString(), currentPageIndex - 1);
124                 sb.AppendFormat("上一页 ", url1);
125             }
126             else
127                 sb.Append("上一页 ");
128             if(mode == PageMode.Numeric)
129                 sb.Append(GetNumericPage(currentPageIndex,pageSize,recordCount,pageCount,url.ToString()));
130             if (currentPageIndex < pageCount)
131             {
132                 string url1 = string.Format(url.ToString(), currentPageIndex+1);
133                 sb.AppendFormat("下一页 ", url1);
134             }
135             else
136                 sb.Append("下一页 ");
137 
138             if (currentPageIndex == pageCount)
139                 sb.Append("末页 ");
140             else
141             {
142                 string url1 = string.Format(url.ToString(), pageCount);
143                 sb.AppendFormat("末页 ", url1);
144             }
145             return sb.ToString();
146         }
147         /// 
148         /// 获取数字分页
149         /// 
150         /// 
151         /// 
152         /// 
153         /// 
154         /// 
155         /// 
156         private static string GetNumericPage(int currentPageIndex, int pageSize, int recordCount, int pageCount,string url)
157         {
158             int k = currentPageIndex / 10;
159             int m = currentPageIndex % 10;
160             StringBuilder sb = new StringBuilder();
161             if (currentPageIndex / 10 == pageCount / 10)
162             {
163                 if (m == 0)
164                 {
165                     k--;
166                     m = 10;
167                 }
168                 else
169                     m = pageCount%10;
170             }
171             else
172                 m = 10;
173             for (int i = k * 10 + 1; i <= k * 10 + m; i++)
174             {
175                 if (i == currentPageIndex)
176                     sb.AppendFormat("{0} ", i);
177                 else
178                 {
179                     string url1 = string.Format(url.ToString(), i);
180                     sb.AppendFormat("{1} ",url1, i);
181                 }
182             }
183             
184             return sb.ToString();
185         }
186     }
187     /// 
188     /// 分页模式
189     /// 
190     public enum PageMode
191     {
192         /// 
193         /// 普通分页模式
194         /// 
195         Normal,
196         /// 
197         /// 普通分页加数字分页
198         /// 
199         Numeric
200     }
201 }
202  PagerQuery.cs包含两个属性,一个是PageInfo实体类属性Pager,包含RecordCount,CurrentPageIndex,PageSize三个属性。一个是Model EntityList属性。 代码    
  1.  using System;  
  2.  using System.Collections.Generic;  
  3.  using System.Linq;  
  4.  using System.Web;  
  5.   namespace System.Web.Mvc  
  6.  {  
  7.      public class PagerQuery  
  8.      {  
  9.         public PagerQuery(TPager pager, TEntityList entityList)  
  10.         {  
  11.             this.Pager = pager;  
  12.             this.EntityList = entityList;  
  13.         }  
  14.         public TPager Pager { getset; }  
  15.         public TEntityList EntityList { getset; }   
  16.     }  
PageInfo.cs

代码

  1.  using System;  
  2.   using System.Collections.Generic;  
  3.   using System.Linq;  
  4.   using System.Web;  
  5. namespace System.Web.Mvc  
  6.   {  
  7.       public class PagerInfo  
  8.       {  
  9.          public int RecordCount { get; set; }  
  10.          public int CurrentPageIndex { get; set; }  
  11.          public int PageSize { get; set; }  
  12.     }  

使用示例:

代码

  1. <%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" 
  2. Inherits="System.Web.Mvc.ViewPage>>" %> 
  3.  
  4.  
  5.     NewsList  
  6.  
  7.  
  8. NewsList

     
  9.     
  10.             
  11.  
  12.             
  13.  
  14.             
  15.  
  16.             
  17.  
  18.             
  19.  
  20.  
  21. <% foreach (var item in Model.EntityList) { %> 
  22.  
  23.  
  24.  
  25.  
  26.  
  27.  
  28.  
  29.  <% } %>
  30. NoteIDTitleAuthorHitReplyNum
     
  31. <%= Html.ActionLink("Edit", "Edit", new { /* id=item.PrimaryKey */ }) %> |  
  32. <%= Html.ActionLink("Details", "NewsDetail", new { noteID=item.NoteID })%> 
  33.  
  34.                 <%= Html.Encode(item.NoteID) %> 
  35.             
  36. <%= Html.Encode(item.Title) %><%= Html.Encode(item.Author)%><%= Html.Encode(item.Hit)%><%= Html.Encode(item.ReplyNum)%>
     
  37.  

  38. <%=Html.Pager("pager",Model.Pager.CurrentPageIndex,Model.Pager.PageSize,Model.Pager.RecordCount,PageMode.Numeric) %>

     
  39.  
  40.  

controler:

  1. [AcceptVerbs(HttpVerbs.Get)]  
  2. ublic ActionResult NewsList(int boardID,int? page)  
  3. {  
  4.     PagerInfo pager = new PagerInfo();  
  5.     NewsArticleInfo info = new NewsArticleInfo();  
  6.     info.NewsBoard = new NewsBoardInfo();  
  7.     info.NewsBoard.BoardID = boardID;  
  8.     pager.RecordCount = Resolve().GetArticleDataList(info, ArticleTypeEnum.Pass);  
  9.     pager.PageSize = 10;  
  10.    pager.CurrentPageIndex = (page!=null?(int)page:1);  
  11.    IList result = Resolve().GetArticleDataList(pager.CurrentPageIndex, pager.PageSize, ArticleTypeEnum.Pass, info);  
  12.    PagerQuery> query = new PagerQuery>(pager,result);  
  13.    return View(query);  

原文标题:一个MVC分页Helper

链接:http://www.cnblogs.com/JackFeng/archive/2010/01/25/JackFeng.html

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...