ASP.NETMVC3Beta初体验之WebGrid

ASP.NET MVC 3 Beta中除了推出一种新的视图引擎Razor。还推出了几种新的HtmlHelper。我比较关注的是WebGrid,这篇文章将介绍一下WebGrid的使用。WebGrid提供了分页和排序的功能,在此之前在MVC中分页和排序时需要自己去写的。这篇文章将分别介绍在aspx视图引擎和Razor视图引擎中如何使用它。

在西华等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供做网站、网站设计 网站设计制作定制网站,公司网站建设,企业网站建设,高端网站设计,营销型网站,外贸网站制作,西华网站建设费用合理。

我通过ADO.NET Entity Data Model从NORTHWND的Products中表中取数据。在Controller中取数据:

 
 
 
 
  1. public class HomeController : Controller      
  2. {        public ActionResult Index()         
  3.  {             
  4.  NORTHWNDEntities entity = new NORTHWNDEntities();              
  5. return View( entity.Products.ToList());        
  6.   }     }  

在aspx视图引擎中使用WebGrid代码如下:

 
 
 
 
  1.     
  2. <% var grid = new WebGrid(source: Model, defaultSort: "ProductName", rowsPerPage: 5); %>   
  3. <%=grid.GetHtml(       
  4. tableStyle: "grid",       
  5. headerStyle: "head",       
  6. alternatingRowStyle: "alt",       
  7. columns: grid.Columns(                 
  8. grid.Column(format: (item) => Html.ActionLink("Edit", "Edit", new { id = item.ProductID })),                 
  9. grid.Column(format: (item) => Html.ActionLink("Delete", "Delete", null, new { onclick = string.Format("deleteRecord('Employee', '{0}')", item.ProductID), @class = "Delete", href = "JavaScript:void(0)" })),                 
  10. grid.Column("ProductName","产品名称"),               
  11. grid.Column("QuantityPerUnit","每单位数量"),                 
  12. grid.Column("UnitPrice","单价"),               
  13. grid.Column("UnitsInStock", "库存单位"),               
  14. grid.Column("UnitsOnOrder","订单单位"),               
  15. grid.Column("ReorderLevel","重新排序级别"),               
  16. grid.Column("Discontinued","已停产")     )     )    %>
  17.  
 

在Razor中使用WebGrid代码如下:

 
 
 
 
  1.   
  2. @{    
  3. var grid = new WebGrid(source: Model,  
  4. defaultSort: "ProductName",   
  5. rowsPerPage: 10);  
  6. }  
  7. @grid.GetHtml(  
  8. tableStyle: "grid",  
  9. headerStyle: "head",  
  10. alternatingRowStyle: "alt",  
  11. columns: grid.Columns(  
  12. grid.Column(format: (item) => Html.ActionLink("Edit", "Edit", new { id = item.ProductID })),  
  13. grid.Column(format: (item) => Html.ActionLink("Delete", "Delete", null, new { onclick = string.Format("deleteRecord('Product', '{0}')", item.ProductID), @class = "Delete", href = "JavaScript:void(0)" })),   
  14. grid.Column("ProductName","产品名称"),  
  15. grid.Column("QuantityPerUnit","每单位数量")  
  16. ,grid.Column("UnitPrice","单价"),  
  17. grid.Column("UnitsInStock", "库存单位"),  
  18. grid.Column("UnitsOnOrder","订单单位"),  
  19. grid.Column("ReorderLevel","重新排序级别"),  
  20. grid.Column("Discontinued","已停产")))
 

WebGrid构造函数如下:

 
 
 
 
  1. public WebGrid(IEnumerable source, 
  2. IEnumerable columnNames = null, 
  3. string defaultSort = null, 
  4. int rowsPerPage = 10, 
  5. bool canPage = true, bool canSort = true, 
  6. string ajaxUpdateContainerId = null, 
  7. string fieldNamePrefix = null, 
  8. string pageFieldName = null, 
  9. string selectionFieldName = null, 
  10. string sortFieldName = null, 
  11. string sortDirectionFieldName = null);  
  12.  

常见参数意思是:

1、source 表示数据源

2、columnNames表示显示的列

3、defaultSort 默认按什么排序

4、rowsPerPage 每页多少行数据

5、canPage 是否能排序

上面两段代码的意思是定义了一个既分页又能排序的grid。

运行:

在看看两个view的完整代码:

aspx:

 
 
 
 
  1. <%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage>" %> 
  2.       
  3. 产品列表  
  4.  
  5.     
  6. function deleteRecord(a, b) {          
  7. alert("删除:"+b);     
  8.  } 
  9.  

    产品列表

        
  10.    
  11. <% var grid = new WebGrid(source: Model, defaultSort: "ProductName", rowsPerPage: 5); %>   
  12. <%=grid.GetHtml(       
  13. tableStyle: "grid",       
  14. headerStyle: "head",       
  15. alternatingRowStyle: "alt",       
  16. columns: grid.Columns(                
  17.  grid.Column(format: (item) => Html.ActionLink("Edit", "Edit", new { id = item.ProductID })),                 
  18. grid.Column(format: (item) => Html.ActionLink("Delete", "Delete", null, new { onclick = string.Format("deleteRecord('Employee', '{0}')", item.ProductID), @class = "Delete", href = "JavaScript:void(0)" })),                 
  19. grid.Column("ProductName","产品名称"),               
  20. grid.Column("QuantityPerUnit","每单位数量"),                 
  21. grid.Column("UnitPrice","单价"),               
  22. grid.Column("UnitsInStock", "库存单位"),               
  23. grid.Column("UnitsOnOrder","订单单位"),               
  24. grid.Column("ReorderLevel","重新排序级别"),               
  25. grid.Column("Discontinued","已停产")     )     )    %> 
 

Razor:

代码 

 
 
 
 
  1.  @model List @{  View.Title = "产品列表"; } 

     

  2. 产品列表

        @{       
  3. var grid = new WebGrid(source: Model,  defaultSort: "ProductName",   rowsPerPage: 3); }  @grid.GetHtml(       
  4. tableStyle: "grid",       
  5. headerStyle: "head",       
  6. alternatingRowStyle: "alt",       
  7. columns: grid.Columns(            
  8. grid.Column(format: (item) => Html.ActionLink("Edit", "Edit", new { id = item.ProductID })),          
  9. grid.Column(format: (item) => Html.ActionLink("Delete", "Delete", null, new { onclick = string.Format("deleteRecord('Product', '{0}')", item.ProductID), @class = "Delete", href = "JavaScript:void(0)" })),             
  10. grid.Column("ProductName","产品名称"),          
  11. grid.Column("QuantityPerUnit","每单位数量"),          
  12. grid.Column("UnitPrice","单价"),            
  13. grid.Column("UnitsInStock", "库存单位"),          
  14. grid.Column("UnitsOnOrder","订单单位"),          
  15. grid.Column("ReorderLevel","重新排序级别"),          
  16. grid.Column("Discontinued","已停产")     )     )   
  17.  

     

Razor去掉了那些模板页的代码,使代码看起来更整洁。比较喜欢Razor。

总结:本文很简单,介绍了一下ASP.NET MVC 3 Beta中新功能WebGrid,由于这种方式WebGrid是在内存中分页和排序的,所以不适合大数据量。

源码下载地址:http://down./data/134994

网页题目:ASP.NETMVC3Beta初体验之WebGrid
文章地址:http://www.mswzjz.cn/qtweb/news26/106326.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能

贝锐智能技术为您推荐以下文章

电子商务知识

各行业网站