最新更新 sitemap 网站制作设计本站搜索
网页设计
国外网站 韩国网站 个人主页 手提袋设计 CSS 网页特效 平面设计 网站设计 Flash CMS技巧 服装网站 php教程 photoshop 画册 服务器选用 数据库 Office
虚拟主机 域名注册 云主机 网页设计 客服QQ:8208442
当前位置:首页 > 编程开发 > asp教程

使用自定义ViewHelper来简化Asp.net

日期:09-26    来源:中国设计秀    作者:cnwebshow.com

 接上篇…首先让我们来看如何创建一个我们先前讨论的textboxlaq中国设计秀
laq中国设计秀
     我们已经知道需要创建的textbox有一个文本值与之对应:laq中国设计秀
laq中国设计秀
文本值在label标签中 laq中国设计秀
可选的值放在Textbox中 laq中国设计秀
可选的验证信息(validation message) laq中国设计秀
      如果上面3个条件都能满足,肯定也能满足我们在part1里的那5个条件.还有一些锦上添花的是可以通过属性来指定textbox是否包裹在li标签内以及textbox是否是readonly模式.这样我们便能更好的在view page中代码复用。下面的代码包含所有HtmlText(译者按:继承AbstractHtmlViewObject对象,在part1的类图中)对象所有的属性:laq中国设计秀
laq中国设计秀
PRivate readonly string mLabelText; laq中国设计秀
private readonly bool mCreateLabel; laq中国设计秀
private readonly object mValue; laq中国设计秀
private readonly string mValidationMessage; laq中国设计秀
private readonly bool mCreateValidationMessage; laq中国设计秀
private readonly bool mCreateLi; laq中国设计秀
private readonly bool mReadonly; laq中国设计秀
laq中国设计秀
public HtmlText( laq中国设计秀
    ViewRequestContext requestContext, string name, string labelText, objeclaq中国设计秀
    string validationMessage, bool @readonly, bool createLi, object attribulaq中国设计秀
    : base(requestContext, name) laq中国设计秀
{ laq中国设计秀
    mLabelText = labelText; laq中国设计秀
    mCreateLabel = !string.IsNullOrEmpty(mLabelText); laq中国设计秀
    mValidationMessage = validationMessage; laq中国设计秀
    mCreateValidationMessage = !string.IsNullOrEmpty(validationMessage); laq中国设计秀
    mCreateLi = createLi; laq中国设计秀
    mReadonly = @readonly; laq中国设计秀
    Attributes = attributes; laq中国设计秀
laq中国设计秀
    object valueToAssign = value; laq中国设计秀
    if (valueToAssign == null) laq中国设计秀
    { laq中国设计秀
        // see if the ModelState has a value for this laq中国设计秀
        valueToAssign = GetModelStateValue(name, typeof(string)); laq中国设计秀
    } laq中国设计秀
laq中国设计秀
    mValue = valueToAssign; laq中国设计秀
}      在构造函数中,我们我们存入一系列私有变量中并初始化了会在StartView方法内使用的一个bool类型,除此之外你可以发现这里开始使用GetModelStateValue方法.目前为止我们先不过多讨论这个方法,这个方法会在后面提到。在参数传入构造器之前我们注意到:laq中国设计秀
laq中国设计秀
value参数的类型是object laq中国设计秀
object类型的attributes参数被传入 laq中国设计秀
    之所以把Value参数定义为object类型是因为这样可以使用户更容易使用并且和asp.net MVC Helpers的执行方式保持一致。attributes参数可以被调用者来扩展生成的HTML。比如说,你想将textbox的maxlength属性设置为5,你只需要传入匿名类型”new {maxlength=5}“.input标签会将这个匿名类型转换为HTML属性maxlength=5.这同时也符合Asp.net MVC中HTML Helper现有扩展方法的使用方式.每一个View helper对象都应该支持这种行为以便具有更大的灵活性.在这个类中剩下的两个方法就是从父类继承来的StartView和EndView方法了.laq中国设计秀
laq中国设计秀
     StartView和EndView的定义如下:laq中国设计秀
laq中国设计秀
public override void StartView() laq中国设计秀
{ laq中国设计秀
    HttpResponseBase httpResponse = RequestContext.HttpResponse; laq中国设计秀
laq中国设计秀
    TagBuilder htmlLiTagBuilder = new TagBuilder("li"); laq中国设计秀
    if (mCreateLi) laq中国设计秀
    { laq中国设计秀
        httpResponse.Write(htmlLiTagBuilder.ToString(TagRenderMode.StartTag)); laq中国设计秀
    } laq中国设计秀
laq中国设计秀
    // write out label if provided laq中国设计秀
    if (mCreateLabel) laq中国设计秀
    { laq中国设计秀
        TagBuilder labelTag = new TagBuilder("label"); laq中国设计秀
        labelTag.Attributes.Add("for", Name); laq中国设计秀
        labelTag.SetInnerText(mLabelText); laq中国设计秀
        httpResponse.Write(labelTag.ToString(TagRenderMode.Normal)); laq中国设计秀
    } laq中国设计秀
laq中国设计秀
    string stringValue = string.Empty; laq中国设计秀
    if (this.mValue != null) laq中国设计秀
    { laq中国设计秀
        stringValue = Convert.ToString(this.mValue, CultureInfo.CurrentCulture); laq中国设计秀
    } laq中国设计秀
laq中国设计秀
    if (this.mReadonly) laq中国设计秀
    { laq中国设计秀
        TagBuilder textTag = new TagBuilder("span");         laq中国设计秀
        textTag.AddcssClass("readonly-text"); laq中国设计秀
        textTag.SetInnerText( laq中国设计秀
            Convert.ToString(this.mValue, CultureInfo.CurrentCulture)); laq中国设计秀
        httpResponse.Write(textTag.ToString(TagRenderMode.Normal)); laq中国设计秀
    } laq中国设计秀
    else laq中国设计秀
    { laq中国设计秀
        // Use MVC helpers to create the actual text box laq中国设计秀
        httpResponse.Write(RequestContext.HtmlHelper.TextBox( laq中国设计秀
            Name, this.mValue, Attributes)); laq中国设计秀
    } laq中国设计秀
laq中国设计秀
    if (this.mCreateLi) laq中国设计秀
    { laq中国设计秀
        httpResponse.Write(htmlLiTagBuilder.ToString(TagRenderMode.EndTag)); laq中国设计秀
    } laq中国设计秀
} laq中国设计秀
public override void EndView() laq中国设计秀
{ laq中国设计秀
    // Not needed for this element laq中国设计秀
} laq中国设计秀
laq中国设计秀
     在StartView方法中有很多值得注意的地方,让我们逐个讨论。首先是我们使用System.Web.Mvc.TagBuilder来生成HTML,而不是直接写HTML标签。TagBuilder只能在Asp.net MVC中使用并且我推荐在生成HTML中必须使用TagBuilder而不是直接写HTML标签,下面是TagBuilder的类图:laq中国设计秀
laq中国设计秀
laq中国设计秀
laq中国设计秀
    laq中国设计秀
laq中国设计秀
下表是TagBuilder中一些方法的说明:laq中国设计秀
laq中国设计秀
名称 描述 laq中国设计秀
AddcssClass 加入css的class名称,如果class已经存在,则后来加入的会和原来的class一起生效 laq中国设计秀
MergeAttribute 这个方法用于添加或者更新tag的属性,这个方法有一个接受replaceExisting参数的重载,默认情况下已经定义的属性不会被重载。 laq中国设计秀
MergeAttributes 同上,只是可以在一个方法内添加或更新所有属性. laq中国设计秀
SetInnerText 设置标签内的文本 laq中国设计秀
ToString 被重载。用于生成相应的html代码,TagRenderMode枚举类型会控制如何生成HTML标签. laq中国设计秀
laq中国设计秀
laq中国设计秀
laq中国设计秀
在上面表格的ToString那行,TagRenderMode枚举用于控制TagBuilder生成HTML标签的方式,TagRenderModel如下所示:laq中国设计秀
laq中国设计秀
TagRenderModel 结果示例 laq中国设计秀
Normal <div name=”Sample01”>Some content here</div> laq中国设计秀
StartTag <div name=”Sample01”> laq中国设计秀
EndTag </div>  laq中国设计秀
SelfClosing <div name=”Sample01” /> laq中国设计秀
    laq中国设计秀
laq中国设计秀
laq中国设计秀
laq中国设计秀
    根据你想创建的HTML标签和你如何使用它,你会发现使用TagRenderModel可以创建出任何你想创建出的HTML.在前面提到的StartView方法内你会发现TagRenderModel被依据不同的条件设置成StartTag,Normal和EndTag等不同的的类型.如果你给InnerHTML属性赋值并用StartTag和EndTag生成它你必须要记住InnerHtml不会被自动生成,你还必须显式的使用InnerHtml属性本身。下面我们来讨论如何创建HtmlHelper扩展方法。laq中国设计秀
laq中国设计秀
-------------------------------------------laq中国设计秀
laq中国设计秀
待续…laq中国设计秀
laq中国设计秀
原文链接:http://mvcviewhelpers.codeplex.com/laq中国设计秀
laq中国设计秀
translated by CareySonlaq中国设计秀
laq中国设计秀
 laq中国设计秀

本文引用地址:/bc/article_46176.html
网站地图 | 关于我们 | 联系我们 | 网站建设 | 广告服务 | 版权声明 | 免责声明