bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

ASP.NETMVC中MvcContrib.FluentHtml如何使用

ASP.NET MVC中MvcContrib.FluentHtml如何使用,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

成都創新互聯公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都網站制作、網站設計、企業官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯網時代的阜陽網站設計、移動媒體設計的需求,幫助企業找到有效的互聯網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!

ASP.NET MVC

在MvcContrib.FluentHtml的應用中,我們隨處可以見到下面的代碼:

<%=this.TextBox(x=>x.Person.Name).Title("Entertheperson'sname").Label("Name:")%><br/>  ……  <%=this.Select(x=>x.Person.Gender).Options(Model.Genders).Size(5).Label("Gender:")  .Title("Selecttheperson'sgender")%><br/>  <labelidlabelid="Person_Name_Label"for="Person_Name">Name:</label> <inputidinputid="Person_Name"type="text"value="Jeremy"title="Entertheperson'sname"name="Person.Name"maxlength="50"/> .  <selectidselectid="Person_Gender"title="Selecttheperson'sgender"size="5"name="Person.Gender"> <optionvalueoptionvalue="M"selected="selected">Male</option> <optionvalueoptionvalue="F">Female</option> </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方法:

publicStringBuilderAppend(stringvalue)  {  if(value!=null)  {  stringstringValue=this.m_StringValue;  IntPtrcurrentThread=Thread.InternalGetCurrentThread();  if(this.m_currentThread!=currentThread)  {  stringstringValue=string.GetStringForStringBuilder(stringValue,stringValue.Capacity);  }  intlength=stringValue.Length;  intrequiredLength=length+value.Length;  if(this.NeedsAllocation(stringValue,requiredLength))  {  stringnewString=this.GetNewString(stringValue,requiredLength);  newString.AppendInPlace(value,length);  this.ReplaceString(currentThread,newString);  }  else  {  stringValue.AppendInPlace(value,length);  this.ReplaceString(currentThread,stringValue);  }  }  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. }  

關于ASP.NET MVC中MvcContrib.FluentHtml如何使用問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創新互聯行業資訊頻道了解更多相關知識。

標題名稱:ASP.NETMVC中MvcContrib.FluentHtml如何使用
文章路徑:http://vcdvsql.cn/article38/pocopp.html

成都網站建設公司_創新互聯,為您提供營銷型網站建設微信公眾號云服務器網站建設商城網站服務器托管

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

外貿網站制作