在本页阅读全文(共2页)
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。
本文导航
- 第1页:标准的 ASP.NET MVC 资料获取