詳解ASP.NET MVC數據分頁

作者: 逆時針  來源: 逆時針  發布時間: 2010-03-24 10:20  閱讀: 21856 次  推薦: 12   [收藏]  

ASP.NET MVC框架已經進入2.0時代,本文將從ASP.NET MVC數據分頁談起,希望能對大家有所幫助。

在網頁上進行表格資料或其他顯示資料的分頁是一種十分常見的需求,以前我們有 GridView 或 DataPager 可以幫我們自動分頁,雖然到了 ASP.NET MVC 一切全部重頭來過,但我們也不用真的那麼辛苦的自己實做分頁,因為早就有人幫我們寫好程式并開放原始碼分享給這個世界了。

如果你已經體會到在 ASP.NET MVC 中妥善利用強型別(Strong Typed)特性進行開發的優點時,你將會發現搭配 Visual Studio 2008 進行專桉開發的過程有多美妙。以下我先舉一個簡單的例子:

你可以在 Controller 中定義一個 Action 方法,并在裡面先取得所有需顯示在 View 中的資料,如果你用 LINQ to SQL 的話,可以直接傳入 IQueryable 型別的物件到 View 中,當成 View 裡面使用的 Model,這樣可以享受延遲載入(Defered Loading) 的效果。

 

代碼
 
public ActionResult Index()
{
IQueryable
<Customer> custs =
from cust in db.Customers
where cust.City == "Taiwan"
select cust;

return View(custs);
}

public ActionResult Index()
{
IQueryable
<Customer> custs =
from cust in db.Customers
where cust.City == "Taiwan"
select cust;

return View(custs);
}
之后在你的 View 中宣告繼承時可透過泛型指派 IQueryable 進去:

 

 

 
<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<IQueryable<Customer>>" %>
<%@ Page Language="C#"
Inherits="System.Web.Mvc.ViewPage<IQueryable<Customer>>" %>
或是轉型成統一個 IEnumable ,這也是比較常見的用法:

 

 

 
<%@ Page Language="C#"
Inherits="System.Web.Mvc.ViewPage<IEnumable<Customer>>" %>
<%@ Page Language="C#"
Inherits="System.Web.Mvc.ViewPage<IEnumable<Customer>>" %>
然后你就可以利用 foreach 取出所有資料并將資料顯示出來了:

 

 

代碼
 
<table>
<% foreach (var item in Model) { %>
<tr>
<td><%= Html.Encode(item.ID) %></td>
<td><%= Html.Encode(item.Name) %></td>
<td><%= Html.Encode(item.Tel) %></td>
</tr>
<% } %>
</table>
<table>
<% foreach (var item in Model) { %>
<tr>
<td><%= Html.Encode(item.ID) %></td>
<td><%= Html.Encode(item.Name) %></td>
<td><%= Html.Encode(item.Tel) %></td>
</tr>
<% } %>
</table>
這就是標準的 ASP.NET MVC 取得資料并顯示在 View 中的 Pattern。

 

  我們最近在開發 ASP.NET MVC 專桉的過程中,除了自行研究如何有效分頁以外,也上網找了好幾套 ASP.NET MVC 分頁的解決方桉,最后我們總結出一個最好用的就是這個元件 ( Paging with ASP.NET MVC )。

  要利用這個元件進行資料分頁,不外乎有幾件事必須做到:

  需傳入一個 page 參數到 Action 中,用以指定你目前要顯示「第幾頁」的資料。

  準備傳入的資料(Model),可透過 Paging with ASP.NET MVC 元件中提供的 Extension Method 將 IList, IQueryable, 或 IEnumable 型別的資料轉換成 IPagedList 的型別,并傳入 View 中。

透過一個自訂的 Html Helper 在 View 中必須顯示「分頁導覽列」的資訊 (如下圖)

  依據上面三個步驟進行修改,Action 的程式碼會變成這樣:

 

 
view plaincopy to clipboardprint?
// 分頁后每頁顯示的筆數
int defaultPageSize = 10;

// 傳入 page 參數 ( 透過 Model Binder 綁進來的 )
public ActionResult Index(int? page)
{
IQueryable
<Customer> custs =
from cust in db.Customers
where cust.City == "Taiwan"
select cust;

// 計算出目前要顯示第幾頁的資料 ( 因為 page 為 Nullable<int> 型別 )
int currentPageIndex = page.HasValue ? page.Value - 1 : 0;

// 透過 ToPagedList 這個 Extension Method 將原本的資料轉成 IPagedList<T>
return View(custs.ToPagedList(currentPageIndex, defaultPageSize));
}

// 分頁后每頁顯示的筆數
int defaultPageSize = 10;

// 傳入 page 參數 ( 透過 Model Binder 綁進來的 )
public ActionResult Index(int? page)
{
IQueryable
<Customer> custs =
from cust in db.Customers
where cust.City == "Taiwan"
select cust;

// 計算出目前要顯示第幾頁的資料 ( 因為 page 為 Nullable<int> 型別 )
int currentPageIndex = page.HasValue ? page.Value - 1 : 0;

// 透過 ToPagedList 這個 Extension Method 將原本的資料轉成 IPagedList<T>
return View(custs.ToPagedList(currentPageIndex, defaultPageSize));
}
然后在 View 中顯示資料的地方,透過一個自訂的 Html Helper 方法顯示分頁資訊。

 

首先必須先修改傳入 View 的 Model 型別

 

 
<%@ Page Language="C#"
Inherits="System.Web.Mvc.ViewPage<IPagedList<Customer>>" %>
<%@ Page Language="C#"
Inherits="System.Web.Mvc.ViewPage<IPagedList<Customer>>" %>
然后再宣告匯入 MvcPaging 命名空間,好讓 Html.Pager 這個 Html Helper Method 可以使用。

 

備注: 也可以在 web.config 設定,請參考 ASP.NET 如何預設匯入指定的命名空間(Namespace) 文章!

 

 
<%@ Import Namespace="MvcPaging"%>
<%@ Import Namespace="MvcPaging"%>
然后原本顯示資料的程式「完全不用改寫」,只要加上「分頁導覽列」即可:

 

 

代碼
 
view plaincopy to clipboardprint?
<table>
<% foreach (var item in Model) { %>
<tr>
<td><%= Html.Encode(item.ID) %></td>
<td><%= Html.Encode(item.Name) %></td>
<td><%= Html.Encode(item.Tel) %></td>
</tr>
<% } %>
</table>

<div class="pager">
<%= Html.Pager(Model.PageSize, Model.PageNumber, Model.TotalItemCount) %>
</div>
<table>
<% foreach (var item in Model) { %>
<tr>
<td><%= Html.Encode(item.ID) %></td>
<td><%= Html.Encode(item.Name) %></td>
<td><%= Html.Encode(item.Tel) %></td>
</tr>
<% } %>
</table>

<div class="pager">
<%= Html.Pager(Model.PageSize, Model.PageNumber, Model.TotalItemCount) %>
</div>

 

就這樣簡單幾個步驟即可完成 ASP.NET MVC 內的分頁了,是不是還不錯呢!

 

12
1
 
標簽:MVC
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()