扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
ASP.NET MVC中MvcContrib.FluentHtml如何使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
成都创新互联公司坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站制作、网站设计、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的阜阳网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
ASP.NET MVC
在MvcContrib.FluentHtml的应用中,我们随处可以见到下面的代码:
<%=this.TextBox(x=>x.Person.Name).Title("Entertheperson'sname").Label("Name:")%>
…… <%=this.Select(x=>x.Person.Gender).Options(Model.Genders).Size(5).Label("Gender:") .Title("Selecttheperson'sgender")%>
Name: . Male Female
这种实现编程方式就是"Fluent Interface",这并不是什么新概念,2005年Eric Evans 和Martin Fowler就为这种实现方式命名.源文档
我们分解上面的话:
◆它是面向对象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>一窥端倪:
publicabstractclassInput
:FormElement whereT:Input ,IElement {
protectedobjectelementValue;
protectedInput(stringtype,stringname):base(HtmlTag.Input,name)
{
builder.MergeAttribute(HtmlAttribute.Type,type,true);
}
protectedInput(stringtype,stringname,MemberExpressionforMember,
IEnumerablebehaviors) :base(HtmlTag.Input,name,forMember,behaviors)
{
builder.MergeAttribute(HtmlAttribute.Type,type,true);
}
///
///Setthe'value'attribute.
///
///<paramnameparamname="value">Thevaluefortheattribute.
publicvirtualTValue(objectvalue)
{
elementValue=value;
return(T)this;
}
///
///Setthe'size'attribute.
///
///<paramnameparamname="value">Thevaluefortheattribute.
publicvirtualTSize(intvalue)
{
Attr(HtmlAttribute.Size,value);
return(T)this;
}
protectedoverridevoidPreRender()
{
Attr(HtmlAttribute.Value,elementValue);
base.PreRender();
}
}
关于ASP.NET MVC中MvcContrib.FluentHtml如何使用问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流