English versionEnglish
杨涛的个人主页

MvcPager分页控件

MvcPager 自定义路由表分页示例—雇员的订单

本示例演示如何使用MvcPager分页控件实现自定义路由分页,分页代码:
<%=Html.Pager(Model,null,"Paging",null ) %>
路由定义如下:
routes.MapRoute("Paging", "{controller}/{action}/employee_{employeeId}/page_{pageIndex}",
new { controller = "Orders", action = "CustomRouteTable", emplyeeId = "1", pageIndex = UrlParameter.Optional });

雇员编号: 雇员1  雇员2  雇员3  雇员4  雇员5  雇员6  雇员7  雇员8  雇员9  
订单编号订单日期顾客编号收货地址
107751997/12/12 0:00:00THECR55 Grizzly Peak Rd.
107771997/12/15 0:00:00GOURLAv. Brasil, 442
107971997/12/25 0:00:00DRACDWalserweg 21
108091998/1/1 0:00:00WELLIRua do Mercado, 12
108181998/1/7 0:00:00MAGAAVia Ludovico il Moro 22
108361998/1/16 0:00:00ERNSHKirchgasse 6
108481998/1/23 0:00:00CONSHBerkeley Gardens 12 Brewery
108681998/2/4 0:00:00QUEENAlameda dos Canàrios, 891
108761998/2/9 0:00:00BONAP12, rue des Bouchers
108801998/2/10 0:00:00FOLKOÅkergatan 24
108901998/2/16 0:00:00DUMON67, rue des Cinquante Otages
108911998/2/17 0:00:00LEHMSMagazinweg 7
108961998/2/19 0:00:00MAISDRue Joseph-Bens 532
109231998/3/3 0:00:00LAMAI1 rue Alsace-Lorraine
109371998/3/10 0:00:00CACTUCerrito 333
109411998/3/11 0:00:00SAVEA187 Suffolk Ln.
109581998/3/18 0:00:00OCEANIng. Gustavo Moncada 8585 Piso 20-A
109931998/4/1 0:00:00FOLKOÅkergatan 24
110081998/4/8 0:00:00ERNSHKirchgasse 6
110301998/4/17 0:00:00SAVEA187 Suffolk Ln.
共2页28条订单
首页  上一页  1  2  下一页  尾页
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" 
Inherits="System.Web.Mvc.ViewPage<PagedList<Order>>" %>
<%@ Import Namespace="MvcPagerSample.Models" %>
<%@ Import Namespace="Webdiyer.WebControls.Mvc" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
	MvcPager 自定义路由表分页示例
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

    <h2>MvcPager 自定义路由表分页示例—雇员的订单</h2>
    <div>本示例演示如何使用MvcPager分页控件实现自定义路由分页,分页代码:<br />
    <%=Html.Pager(Model,null,"Paging",null ) %>
    <br /><strong>路由定义如下:</strong><br />
    routes.MapRoute("Paging", "{controller}/{action}/employee_{employeeId}/page_{pageIndex}",
     <br /> new { controller = "Orders", action = "EmployeeOrders", 
     emplyeeId = "1", pageIndex = UrlParameter.Optional });
    </div><br />
    <div>雇员编号:
    <%
        int empId = Convert.ToInt32(ViewContext.RouteData.Values["employeeId"]);
    for(int i=1;i<10;i++)
      {
          if (empId == i)
              Response.Write("雇员" + i);
          else
          Response.Write(Html.RouteLink("雇员" + i,"Paging",
            new RouteValueDictionary { { "action", "EmployeeOrders" },
            {"controller","Orders"}, { "employeeId", i }, { "pageIndex", 1 } },null));
          Response.Write("  ");
      } %>
    </div>
<table width="98%">
<tr><th>订单编号</th><th>订单日期</th><th>顾客编号</th><th>收货地址</th></tr>
<%foreach(Order od in Model)
 {
     %>
     <tr><td><%=od.OrderID %></td><td><%=od.OrderDate.ToString() %></td>
     <td><%=od.CustomerID %></td><td><%=od.ShipAddress %></td></tr>
     <%
 } %>
</table>
<div style="float:left;width:30%"><%="共"+Model.TotalPageCount+"页"+
Model.TotalItemCount+"条订单" %>
</div><div style="float:right">
 <%=Html.Pager(Model,null,"Paging",null )%></div>
</asp:Content>
    
    
public ActionResult CustomRouteTable(int employeeId, int? pageIndex)
{
    using(var db=new MvcPagerSampleDataContext())
    {
	PagedList<Order> pagedOrders =
	db.Orders.Where(o => o.EmployeeID == employeeId).ToPagedList(pageIndex ?? 1, 20);
	return View(pagedOrders);
    }
}