Asp.net MVC4.0自定义Html辅助方法
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Web; using System.Web.Mvc; namespace MyEF.ExtentionHtmlHelper { public static class ImageHelper { //说明:因为C#3.0的扩充方法是一种特殊的静态方法,因此在开发Html辅助方法时必须声明为 //静态方法(static method)并放在一个静态的类别里面!此外自定义的Html方法还有一个重点,那就是从Html辅助方法里,回传的类型可以使简单的String字符串类型,也可以是System.Web.MvcHtmlString类别,差别在于,通过rasor输出的Html预设就会对所有输出的Html编码动作,所以如果回传string字符串类型,其输出的内容将会被Html编码后输出,如果你从Html辅助方法回传MvcHtmlString类型的话,如果内容包含标签数据,那么就会原封不动的输出Html标签,以我们的这个范例来说,必须回传MvcHtmlString类别,代码范例如下: public static MvcHtmlString HtmlImg(this HtmlHelper helper, string url, string alternateText, string title) { return MvcHtmlString.Create(string.Format("<img src=‘{0} alt={1}‘ title=‘{2}‘ />", url, alternateText, title)); } public static MvcHtmlString HtmlImg(this HtmlHelper helper, string linkUrl, string target, string imgUrl, string alterText, string title) { StringBuilder sb = new StringBuilder(); sb.Append("<a href=\""); sb.Append(linkUrl); sb.Append("\" target=\""); sb.Append(target); sb.Append("\">"); sb.Append("<img src=\""); sb.Append(imgUrl); sb.Append("\""); sb.Append("\" alt=\""); sb.Append(alterText); sb.Append("\""); sb.Append("\" title=\""); sb.Append(title); sb.Append("\" /></a>"); return MvcHtmlString.Create(sb.ToString()); } } }
这种利用StringBuilder组子串的方式没有任何弹性,ASP.NET MVC专门为了产生HTML标签的需求而设计了一个TagBuilder类别,能够以更物件化的方式产生HTML标签,接着来改写上述范例,以TagBuilder实例如下:
public static MvcHtmlString ImageLink(this HtmlHelper helper,string actionName,string imgUrl, string alternateText,object routeValues,object linkHtmlAttributes,object imageHtmlAttributes) { var urlHelper = new UrlHelper(helper.ViewContext.RequestContext); var url = urlHelper.Action(actionName, routeValues); //建立链接 var linkTagBuilder = new TagBuilder("a"); linkTagBuilder.MergeAttribute("href", url); linkTagBuilder.MergeAttributes(new RouteValueDictionary(linkHtmlAttributes)); //建立图片 var imageTagBuilder = new TagBuilder("img"); imageTagBuilder.MergeAttribute("src", urlHelper.Content(imgUrl)); imageTagBuilder.MergeAttribute("alt",alternateText); imageTagBuilder.MergeAttribute("title",alternateText); imageTagBuilder.MergeAttributes(new ViewDataDictionary(imageHtmlAttributes)); //将图片加之连接中 linkTagBuilder.InnerHtml = imageTagBuilder.ToString(TagRenderMode.SelfClosing); return MvcHtmlString.Create(linkTagBuilder.ToString()); }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。