zoukankan      html  css  js  c++  java
  • MVC 自定义标签,给Html.ActionLink加上支持图片链接的功能

    转载:http://blog.csdn.net/niewq/article/details/17537873

    Html.ActionLink只支持文字链接,现在我们利用C#的扩展方法写一个Html.ActionLinkWithImage()让其支持图片链接的功能。
    一、首先新建一个静态类,将命名空间在改在System.Web.Mvc下,代码如下

    using System; 
    using System.Collections.Generic; 
    using System.Linq; 
    using System.Web; 
    using System.Web.Mvc; 
    namespace System.Web.Mvc 
    { 
        public static class MyHelpler 
        { 
            public static MvcHtmlString ActionLinkWithImage(this HtmlHelper html, string imgSrc, string actionName) 
            { 
                var urlHelper = new UrlHelper(html.ViewContext.RequestContext); 
    
                string imgUrl = urlHelper.Content(imgSrc); 
                TagBuilder imgTagBuilder = new TagBuilder("img"); 
                imgTagBuilder.MergeAttribute("src", imgUrl); 
                string img = imgTagBuilder.ToString(TagRenderMode.SelfClosing); 
    
                string url = urlHelper.Action(actionName); 
    
                TagBuilder tagBuilder = new TagBuilder("a") 
                { 
                    InnerHtml = img 
                }; 
                tagBuilder.MergeAttribute("href", url); 
    
                return new MvcHtmlString(tagBuilder.ToString(TagRenderMode.Normal)); 
            } 
            public static MvcHtmlString ActionLinkWithImage(this HtmlHelper html, string imgSrc, string actionName,string controllerName,object routeValue=null) 
            { 
                var urlHelper = new UrlHelper(html.ViewContext.RequestContext); 
    
                string imgUrl = urlHelper.Content(imgSrc); 
                TagBuilder imgTagBuilder = new TagBuilder("img"); 
                imgTagBuilder.MergeAttribute("src", imgUrl); 
                string img = imgTagBuilder.ToString(TagRenderMode.SelfClosing); 
    
                string url = urlHelper.Action(actionName, controllerName, routeValue); 
    
                TagBuilder tagBuilder = new TagBuilder("a") 
                { 
                    InnerHtml = img 
                }; 
                tagBuilder.MergeAttribute("href", url); 
    
                return new MvcHtmlString(tagBuilder.ToString(TagRenderMode.Normal)); 
            } 
        } 
    }

    二、在view下使用:

    @Html.ActionLinkWithImage(Url.Content("~/Content/images/index_1.gif"), "Index")
    
    @Html.ActionLinkWithImage(Url.Content("~/Content/images/index_2.gif"), "List","Admin", new { id=1})

    MVC的带链接的图片标签就完成了,可以传入跳转到制定的控制器、方法、以及传入参数等。

  • 相关阅读:
    leetcode_24. 两两交换链表中的节点
    Mysql大数据量分页优化
    MySQL 默认排序是什么
    spring注入map,spring注入一个接口的多个实现类在map里
    eureka缓存细节以及生产环境的最佳配置
    MySQL 5.7性能调优
    安装后的十个MySQL性能调整设置(版本:5.1、5.5 和5.6)
    docker部署tomcat应用和MySQL数据库
    MySQL热备工具Xtrabackup
    MySQL数据库的冷备方式
  • 原文地址:https://www.cnblogs.com/yuanye0918/p/4310521.html
Copyright © 2011-2022 走看看