zoukankan      html  css  js  c++  java
  • ASP.NET MVC 之自定义HtmlHelper

    前言

        HtmlHelper方法为我们提供很多html标签,只需在页面调用就行了,但是微软并没有把所有的html标签都对应有了扩展方法,需要我们重新自定义HtmlHelper,来满足我们需要。

    方法

     如下例代码:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    namespace TestMvcHelper
    {
        public static class HtmlExtensions
        {
            public static MvcHtmlString Submit(this HtmlHelper helper, string value)
            {
                var builder = new TagBuilder("input"); //使我们创建的标签名字设为input
                builder.MergeAttribute("type", "submit");  //添加属性 type="submit"
                builder.MergeAttribute("value", value);
                return MvcHtmlString.Create(builder.ToString(TagRenderMode.SelfClosing)); 
            }
        }
    }

    上面代码解读:

    • 在使用TagBuilder需要引入命名空间System.Web.Mvc。
    • Submit方法名是对应视图中调用的名称。    (如:@Html.Submit("提交") )
    • this HtmlHelper helper 将Submit方法添加到HtmlHelper中,value是传过来的提交按钮上的文字。
    • var builder = new TagBuilder("input");      设置标签名字设为input。
    • builder.MergeAttribute("type", "submit")   设置标签属性type="submit"。
    • builder.MergeAttribute("value", value);      设置标签提交按钮Value值。
    • TagRenderMode.SelfClosing                     表示用于呈现自结束标记(例如,<input />)的模式。
    • TagRenderMode是个枚举类,分别为   Normal(表示用于呈现正常文本的模式)、StartTag(表示用于呈现开始标记(例如,<tag>)的模式)、 EndTag(表示用于呈现结束标记(例如,</tag>)的模式)、 SelfClosing(表示用于呈现自结束标记(例如,<tag />)的模式)。
    • MvcHtmlString作为返回值是为了使返回值不被转义,比如"<"不会被转成"&lt"。

    View中写入下面代码调用

    @Html.Submit("提交")

    生成效果预览

    <input type="submit" value="提交" />

    本篇到此结束。HtmlHelper包含的东西比较多,还有一些东西没有介绍,有时间我会继续学习,如果大家有兴趣我可以继续拓展。欢迎讨论。喜欢的话就推荐一下吧!

  • 相关阅读:
    记一次小程序之旅
    基于supervisor秒级Laravel定时任务
    如何在Ubuntu16.04 中安装Linux, Nginx, MySQL, PHP (LEMP 栈)
    从CSV文件中读取jpg图片的URL地址并多线程批量下载
    关于PHP程序员解决问题的能力
    Laradock 快速搭建PHP开发环境
    array_map 等php回调函数使用问题(关联数组下标获取)
    Laravel-Action 对代码的改造
    Sessions共享技术设计
    scrapy 写文件进行debug调试
  • 原文地址:https://www.cnblogs.com/liujie2272/p/5344605.html
Copyright © 2011-2022 走看看