热点推荐
ZOL首页 > 企业信息化 > 基础软件 > 开发平台 > 详解ASP.NET MVC框架数据分页妥善设计

详解ASP.NET MVC框架数据分页妥善设计


博客园 【转载】 2010年04月10日 05:08 评论

    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 2 下一页
本文导航
  • 第1页:标准的 ASP.NET MVC 资料获取
频道热词:LED照明  云计算  无线路由器  
视觉焦点
企业信息化基础软件热点
排行 文章标题
TOP10周热门OA办公自动化排行榜
  • 热门
  • 新品
查看完整榜单>>