随笔-20  评论-487  文章-1  trackbacks-14
      最近看到园子里有朋友在翻译一些关于ASP.NET MVC的文章,很是不错,饶有兴趣看了下原作者的博客(http://weblogs.asp.net/stephenwalther),看到其中有两篇写关于GridView的,方才想起来自己曾经也抽空写过这方面的控件(http://www.hereur.cn/SiChuanEarthquake.xhtml/LoveWall 下方的Table就是用这个扩展方法做的),思路大体一致,不过同样作为其中一种HtmlHelper扩展出来的方法,stephenwalther的方法和我第一个版本的差不多,但是正如他说的,有很多缺点,后来我也在使用中确实发现了这些问题,又改进了一下,觉得对于那些不需要太复杂逻辑的情况,还是挺实用的,发出来与大家分享。

同样是替代传统的”header+ foreach + footer ”的方法,我做了两个扩展方法,分别是RepeaterGridView,因为Repeater相对简单和基础,用于轻量级的情况。这里先把Repeater发上来。

首先明确一下这个Repeater的功能:

1、能够根据需要自由转换<div>,<table>,<ul>标签等格式,也可不套用任何格式。并且当使用Table时,可以随意指定其每行显示的单元格数,当最后一行有零头时,自动填充剩余的空单元格。

2、能够在方法中完成自定义headerfooter的工作(类似这些“庞杂”的工作应该说是在MVC中催生出RepeaterGridView等插件的主要动因),让整个RepeaterWebForm中一样达到“一体化”,而不再是这样的局面:

<ul>

<% foreach (var item in collection){%>

<li><%= item %></li>     

<% } %>

</ul>

想象一下在包含theadtbodytable中将更加复杂。当然这样的形势并不是一无是处的,对于美工等前台控制,这些直白的表达方式更加利于我们的操作和控制。所以必须说明的一点是:当需要对其进行很复杂的操作的时候,不要滥用这些扩展方法,否则会给维护带来很多不便。

为了达到上面说的第一点,我们先建一个枚举类型,用于指定使用哪种格式:

(包含在MvcTool/RepeaterExtension.cs中)

       

public enum RepeaterMode
        
{
            
/// <summary>
            
/// 不自动加任何多于标记,等同于foreach。但header和footer仍然有效
             
/// </summary>

            None = 0,
            Table,
            Div,
            Ul
        }


然后我们来建一个RepeaterExtension类,用于在aspx页面的HtmlHelper方法中扩展这个Repeater

(也包含在MvcTool/RepeaterExtension.cs中)

       

public class SingleRepeater : IDisposable
        
{
           …
        }


        
/// <summary>
        
/// Repeater
        
/// </summary>
        
/// <typeparam name="T"></typeparam>
        
/// <param name="helper"></param>
        
/// <param name="dataSource">数据源</param>
        
/// <param name="header">第一个单项循环开始之前的内容</param>
        
/// <param name="itemTempletes">单项内容</param>
        
/// <param name="separatorTemplate">每次循环分隔内容(Table慎用)</param>
        
/// <param name="footer">最后一个单项循环结束之后的内容</param>
        
/// <param name="repeaterMode">repeater模式</param>
        
/// <param name="colCount">每行烈数(只在repeaterMode为Table时有效)</param>
        
/// <param name="htmlAttributes">标签属性</param>
        
/// <returns></returns>

        public static string Repeater<T>(this HtmlHelper helper, IEnumerable<T> dataSource,
            
string header, Expression<Func<T, string>> itemTempletes, Expression<Func<T, string>> separatorTemplate, string footer,

            RepeaterMode repeaterMode, 
int colCount, object htmlAttributes)
        
{
            …
        }

RepeaterExtension 主要包含了两个方法:SingleRepeater()Repeater<T>(),因为里面具体实现的代码比较长,这里省略了,大家可以在下面提供的下载中察看MvcTool/RepeaterExtension.cs文件。对于SingleRepeater()大家可能会有点疑问:是否需要存在?是否需要继承IDisposable?我这里就此简要说明一下用意:目前的这些代码中,无论是SingleRepeater()还是继承IDisposable的行为,都是可以被简化并且整合到Repeater<T>()方法中的,这里这么做是为了给页面表现形式留有一个升级的余地,比如在using()中书写等等(为了更好的对页面进行控制)。

public enum RepeaterMode这个枚举大家也可以根据自己的需要扩展,比如<ol>等等。

下面我们来一下aspx如何使用:

<%= Html.Repeater(ViewData.Model.UserInfo,//数据源
    
"",//header
    z
=> string.Format("{0} ,年龄:{1}", z.UserName,z.Age),//item模板,为了在页面得到数据的完全控制,必须返回string类型
    z
=> "",//间隔
    
"",//footer
    RepeaterExtension.RepeaterMode.Ul,
//重复的方式(table,div,ul
    
0,//如果使用Table,则指定其显示的列数
    
null//最外层标签的属性,object类型
    ) 
%>

其中RepeaterExtension.RepeaterMode.Ul用于指定这个Repeater的展现方式为Ul/Li。

         我们来看看实际输出的效果:

UL(即上述代码输出)


Table
形式(5列):



不使用任何格式(
header为“[”,footer为“]”,间隔为“|”):


代码下载:/Files/szw/MVCRepeater.rar

PS:这个Repeater扩展对输出内容较为简单的代码能起到很好的提高开发效率的作用,不光在MVC能用,在WebForm里面也是可以的。同时其中的一些思想和参数用法,也是对接下来要讲的GridView的一个基础和热身。下一篇:为ASP.NET MVC开发一些常用插件(四)——GridView。

http://szw.cnblogs.com/
研究、探讨ASP.NET
转载请注明出处和作者,谢谢!

posted on 2008-07-09 14:01 SZW 阅读(1550) 评论(14)  编辑 收藏 所属分类: 原创ASP.NETASP.NET MVC

评论:
#1楼  2008-07-09 14:18 | 阿不      
支持类似Repeater的模板不?
  回复  引用  查看    
#2楼 [楼主] 2008-07-09 14:28 | SZW      
Repeater在这里作为一个“轻量级”的方法出现,在下面GridView中你会看到模板:)
  回复  引用  查看    
#3楼  2008-07-09 14:31 | 阿不      
Repeater更应用有模板,没有模板Repeater发挥不出它的功效。
  回复  引用  查看    
#4楼 [楼主] 2008-07-09 14:32 | SZW      
你说的模板是具有哪些功能的模板?
  回复  引用  查看    
#5楼  2008-07-09 17:29 | Q.Lee.lulu      
MVC的文章都要顶!!
  回复  引用  查看    
#6楼 [楼主] 2008-07-09 18:58 | SZW      
@Q.Lee.lulu
嘿嘿:)
  回复  引用  查看    
#7楼  2008-07-09 18:59 | 阿不      
@SZW
模板功能就是要像普通的Repeater一样,有ItemTemplate啊
  回复  引用  查看    
#8楼 [楼主] 2008-07-09 19:36 | SZW      
我不知道你说的是像WebFrom服务器控件那样继承自ITemplete那样的“模板”,还是repeat循环体内的的输出?
(汗,明明是跟贴的,怎么编辑掉了?bug?)

  回复  引用  查看    
#9楼  2008-07-09 19:40 | 阿不      
就是“模板”
  回复  引用  查看    
#10楼 [楼主] 2008-07-09 19:44 | SZW      
那里面的itemTempletes已经可以达到这些基本要求了哇
  回复  引用  查看    
#11楼 [楼主] 2008-07-09 20:06 | SZW      
继承自ITemplete的“模板”我觉得在MVC里面似乎不太用的到啊,本身就不提倡使用runat=server的控件,那么所谓“模板”能直接输出HTML代码就已经OK了阿
  回复  引用  查看    
#12楼  2008-07-10 09:08 | 菜无罪1      
mvc正式版发布没有,回到asp,没有控件的时代了。
  回复  引用  查看    
#13楼 [楼主] 2008-07-10 10:39 | SZW      
@菜无罪1
正式版还没有发布。从单纯页面开发上来说确实很asp,当然这个“没有控件”也只是针对V层的开发而言,MVC本身在这方面追求的就是这种高度的可控性,其他语言和结构方面的优势还是和WebForm没有太大区别的:)
  回复  引用  查看    
#14楼  2008-09-10 17:24 | 郁闷的翩翩      
很好很强大。
  回复  引用  查看    

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-07-09 14:46 编辑过


相关链接: