浅谈ASP.NET MVC的MvcContrib.FluentHtml

开发 后端
本文将以ASP.NET MVC平台上MvcContrib.FluentHtml为例探究它的实现机制:Fluent Interface.

我们力求页面层代码简洁并具有较好的可读性,在ASP.NET MVC的平台上,我们以新的起点来实现这一目标.MvcContrib.FluentHtml和Spark ViewEngine给我们做出了榜样.本文将以MvcContrib.FluentHtml为例探究它的实现机制:Fluent Interface.

ASP.NET MVC

在MvcContrib.FluentHtml的应用中,我们随处可以见到下面的代码:

 

  1. <%=this.TextBox(x=>x.Person.Name).Title("Entertheperson'sname").Label("Name:")%><br/> 
  2.  
  3. ……  
  4. <%=this.Select(x=>x.Person.Gender).Options(Model.Genders).Size(5).Label("Gender:")  
  5. .Title("Selecttheperson'sgender")%><br/> 
  6.  
  7. <labelidlabelid="Person_Name_Label"for="Person_Name">Name:</label> 
  8. <inputidinputid="Person_Name"type="text"value="Jeremy"title="Entertheperson'sname"name="Person.Name"maxlength="50"/> 
  9. .  
  10. <selectidselectid="Person_Gender"title="Selecttheperson'sgender"size="5"name="Person.Gender"> 
  11. <optionvalueoptionvalue="M"selected="selected">Male</option> 
  12. <optionvalueoptionvalue="F">Female</option> 
  13. </select> 

 


这种实现编程方式就是"Fluent Interface",这并不是什么新概念,2005年Eric Evans 和Martin Fowler就为这种实现方式命名.源文档 <http://www.martinfowler.com/bliki/FluentInterface.html> 可以通过维基百科中对Fluent Interface的描述获得一个基本的了解:In software engineering, a fluent interface (as first coined by Eric Evans and Martin Fowler) is a way of implementing an object oriented API in a way that aims to provide for more readable code.

我们分解上面的话:
◆它是面向对象API的一种实现方式
◆目的是增加代码的可读性

既然我们最熟悉的是StringBuilder,我们就从这个线索追下去:打开Reflector,很容易找到StringBuilder的Append方法:

 

  1. publicStringBuilderAppend(stringvalue)  
  2. {  
  3. if(value!=null)  
  4. {  
  5. stringstringValue=this.m_StringValue;  
  6. IntPtrcurrentThread=Thread.InternalGetCurrentThread();  
  7. if(this.m_currentThread!=currentThread)  
  8. {  
  9. stringstringValue=string.GetStringForStringBuilder(stringValue,stringValue.Capacity);  
  10. }  
  11. intlength=stringValue.Length;  
  12. intrequiredLength=length+value.Length;  
  13. if(this.NeedsAllocation(stringValue,requiredLength))  
  14. {  
  15. stringnewString=this.GetNewString(stringValue,requiredLength);  
  16. newString.AppendInPlace(value,length);  
  17. this.ReplaceString(currentThread,newString);  
  18. }  
  19. else  
  20. {  
  21. stringValue.AppendInPlace(value,length);  
  22. this.ReplaceString(currentThread,stringValue);  
  23. }  
  24. }  
  25. returnthis;  


了解了Fluent Interface,我们来看一下MVCContrib.FluentHTML的实现,这里以TextBox为例进行考察,首先看一下它的继承关系:

public class TextBox : TextInput< TextBox>

public abstract class TextInput< T> : Input< T>, ISupportsMaxLength where T : TextInput< T>

public abstract class Input< T> : FormElement< T> where T : Input< T>, Ielement

泛型是一种高层次的算法抽象,我们就通过Input< T>一窥端倪:

 

  1. publicabstractclassInput<T>:FormElement<T>whereT:Input<T>,IElement  
  2. {  
  3. protectedobjectelementValue;  
  4.  
  5. protectedInput(stringtype,stringname):base(HtmlTag.Input,name)  
  6. {  
  7. builder.MergeAttribute(HtmlAttribute.Type,type,true);  
  8. }  
  9.  
  10. protectedInput(stringtype,stringname,MemberExpressionforMember,
    IEnumerable
    <IBehaviorMarker>behaviors)  
  11. :base(HtmlTag.Input,name,forMember,behaviors)  
  12. {  
  13. builder.MergeAttribute(HtmlAttribute.Type,type,true);  
  14. }  
  15.  
  16. ///<summary> 
  17. ///Setthe'value'attribute.  
  18. ///</summary> 
  19. ///<paramnameparamname="value">Thevaluefortheattribute.</param> 
  20. publicvirtualTValue(objectvalue)  
  21. {  
  22. elementValue=value;  
  23. return(T)this;  
  24. }  
  25.  
  26. ///<summary> 
  27. ///Setthe'size'attribute.  
  28. ///</summary> 
  29. ///<paramnameparamname="value">Thevaluefortheattribute.</param> 
  30. publicvirtualTSize(intvalue)  
  31. {  
  32. Attr(HtmlAttribute.Size,value);  
  33. return(T)this;  
  34. }  
  35.  
  36. protectedoverridevoidPreRender()  
  37. {  
  38. Attr(HtmlAttribute.Value,elementValue);  
  39. base.PreRender();  
  40. }  

总结

为了能够在View中能够简洁清晰的构造HTML元素,ASP.NET MVC中通过htmlHelper.InputHelper来实现页面元素的构造. 页面层所使用的<%= Html.TextBox("username") %>,HTML也是htmlHelper的Extension Method.相比较起来,htmlHelper提供了基础的页面控件定义和构造,而FluentHTML表现的更为灵活.除了FluentHTML,著名的Spark View Engine也有类似的实现,大家可以关注一下.

【编辑推荐】

  1. 使用C#实现ASP.NET控件数组
  2. 浅析因Session导致的ASP.NET网站性能问题
  3. ASP.NET开发程序过程中值得注意的两个地方
  4. 浅谈基于URL的权限控制ASP.NET MVC中的实现
  5. ASP.NET、JSP和PHP究竟哪个好
责任编辑:佚名 来源: 网管员世界
相关推荐

2009-06-15 10:57:51

FluentHtmlASP.NET MVC

2009-07-23 15:44:39

ASP.NET MVC

2009-07-22 13:24:24

ASP.NET MVC

2009-12-07 09:23:05

ASP.NET MVC

2009-12-21 10:05:10

ASP.NET MVC

2009-07-24 13:20:44

MVC框架ASP.NET

2009-07-22 16:11:43

ASP.NET AJA

2009-07-20 15:30:11

ASP.NET应用

2011-01-28 09:45:29

ASP.NET MVC

2009-07-31 12:43:59

ASP.NET MVC

2009-07-24 10:52:42

ASP.NET ISA

2009-07-22 10:34:37

ActionInvokASP.NET MVC

2009-07-07 10:14:57

基于URL权限控制

2009-07-28 18:00:11

ASP.NET程序

2009-07-27 13:01:28

TreeViewASP.NET

2009-07-21 14:16:02

ASP.NET管道优化

2009-07-23 15:24:37

ASP.NET Ima

2011-08-23 10:58:59

2009-07-27 16:19:59

ASP.NET报表控件

2009-07-20 15:44:32

ASP.NET MVC
点赞
收藏

51CTO技术栈公众号