码迷,mamicode.com
首页 > Web开发 > 详细

asp.net mvc Htmlhelper简单扩展

时间:2014-08-18 18:14:12      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   io   for   2014   

bubuko.com,布布扣

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;

namespace WebApplication1.MyHtmlHelper
{
    public static class MyHtmlHelper
    {
        //页面渲染结果:
        //<span>我扩展的Label,自动生成Span标签</span>
        //把标签名都显示(直接将内容显示)
        public static string MyHtmlLable1(this HtmlHelper html,string lableName)
        { 
            return string.Format("<span>{0}</span>",lableName);
        }
        
        public static HtmlString MyHtml(this HtmlHelper html, string value)
        {
            return new HtmlString(value);
        }

        //页面渲染结果:
        //span标签
        public static HtmlString MyHtmlLable2(this HtmlHelper html, string lableName)
        {
            return MyHtml(html,string.Format("<span>{0}</span>", lableName));
        }

        //页面渲染结果:
        //input标签
        public static HtmlString MyTextBox(this HtmlHelper html,string content)
        { 
            return MyHtml(html,string.Format("<input type=‘type‘ value=‘{0}‘/>",content));
        }




    }
}

@using WebApplication1.MyHtmlHelper
@{
    ViewBag.Title = "Test";
}

<h2>Test</h2>

@*结果:<span>我扩展的Label,自动生成Span标签</span>*@ 
@Html.MyHtmlLable1("我扩展的Label,自动生成Span标签") <br />

@*结果:我扩展的Label,自动生成Span标签*@ 
@Html.MyHtmlLable2("我扩展的Label,自动生成Span标签") <br />

@*结果:span标签测试*@ 
@Html.MyHtml("span标签测试") <br />

@*textbox*@ 
@Html.MyTextBox("textbox") <br />

 

 

所有标签定义方法:

 
        public static string SelfDefineTagString(this HtmlHelper helper, string tagName, string id, string name, string className,string value, string style)
        {
            //创建标签
            TagBuilder tb = new TagBuilder(tagName);
            //定义标签id
            tb.GenerateId(id);
            //定义标签name
            tb.MergeAttribute("name", name);
            //定义标签class
            tb.AddCssClass(className);
            //定义标签样式
            tb.MergeAttribute("style", style);
            //定义标签内容
            tb.SetInnerText(value);
            return tb.ToString();
        }

        public static HtmlString SelfDefineTag(this HtmlHelper helper, string tagName, string id, string name, string className,string value, string style)
        {
            return new HtmlString(SelfDefineTagString(helper, tagName, id, name, className, value, style));
        
        }

 


html调用方法:

@Html.SelfDefineTag("p", "test", "test", "test", "p标签", "color:red;background:#ccc;width:100px;text-align:center")

asp.net mvc Htmlhelper简单扩展,布布扣,bubuko.com

asp.net mvc Htmlhelper简单扩展

标签:style   blog   http   color   os   io   for   2014   

原文地址:http://www.cnblogs.com/zoro-zero/p/3920015.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!