MVC HTML辅助方法

2021-04-25 12:27

阅读:649

标签:rop   过程   命名方式   错误   strong   net   帮助   online   因此   

HTML辅助方法(HTML Helper)用来辅助产生HTML,在开发View的时候会面对许多HTML标签,处理这些HTML标签非常繁琐,为了降低View的复杂度,可以使用HTML辅助方法帮助你产生一些HTML标签或内容,因这些HTML标签都有固定标准的写法,所以将其包装成HTML辅助方法,可让View开发更快速,也可以避免不必要的语法错误。

ASP.NET MVC中内建了许多HTML辅助方法,这些HTML辅助方法都是利用C#3.0的扩充方法特性,将各种不同的HTML辅助方法扩充在HtmlHelper类别里,并且都拥有多载。

通过HTML辅助方法可以有效协助你面对常见但又繁琐的HTML编写工作,例如,超链接、表单声明(

)、表单元素(

Html.Password(),输出标签

Html.CheckBox(),输出标签

Html.RadionButton(),输出标签

Html.DropDownList(),输出

Html.ListBox(),输出

Html.Hidden(),输出标签

Html.ValidationSummary(),输出表单验证失败时的错误信息摘要

a.标签的使用

@Html.Label("Username","账户")
@Html.TextBox("Username")

技术图片

b.文本框的使用

Html.TextBox的重载如下:

@Html.TextBox("Username")  //id,name的值为Username

@Html.TextBox("Username", "will")  //id,name的值为Username; value的值为will

@Html.TextBox("Username", "will", new { size=32 })//id,name的值为Username; html属性值size=3

如果要传递多个html属性值,并且在多处使用,可以按照下面的例子来做。

技术图片
技术图片
public ActionResult HelperSample1()
        {
            IDictionary attr = new Dictionary();
            attr.Add("size", "32");
            attr.Add("style", "color:red;");
            ViewData["Dictionary"] = attr;
            return View();
        }
技术图片
技术图片
技术图片
技术图片
@{
    var htmlAttribute = ViewData["Dictionary"] as IDictionary;
}
@Html.TextBox("name","Value",htmlAttribute)
@Html.Password("password","Value",htmlAttribute)
@Html.TextBox("email","Value",htmlAttribute)
@Html.TextBox("tel","Value",htmlAttribute)
@Html.Hidden("id","1")
技术图片
技术图片

c.Html.DropDownList()的使用

1)不读取数据库的下拉列表

技术图片
技术图片
public ActionResult HelperSample2()
        {
            List listItem = new List();
            listItem.Add(new SelectListItem { Text = "是", Value = "1" });
            listItem.Add(new SelectListItem { Text = "否", Value = "0" });
            ViewData["List"] = new SelectList(listItem, "Value", "Text", "");
            return View();
        }
技术图片
技术图片
@Html.DropDownList("List", ViewData["List"] as SelectList, "请选择")  //参数依次为下拉列表的名字,指定的列表项,默认选择项的值

2)数据来自数据库的下拉列表

技术图片
技术图片
public ActionResult Index()
        {
            var list = new SelectList(db.Students, "Id", "Age", "3");  //参数依次为数据集合,数据值,数据文本,选中项的值
            ViewBag.List = list;
            return View();
        }
技术图片
技术图片
@Html.DropDownList("List")

3)数据来自枚举类型

ViewBag.Role = new SelectList(Enum.GetValues(typeof(SystemRole)), "");
@Html.DropDownList("Role")

(3)使用强类型辅助方法

        ASP.NET MVC从2.0版开始更进一步地提供了强类型的辅助方法,避免因为输入错误而导致数据没有显示或是编辑时无法存储的问题,除此之外,如果能活用这些强类型辅助方法还能提升整体开发效率。

        基本上,属于强类型的辅助方法命名方式皆为“原先的名称最后加上For”,例如,Html.TextBoxFor()或Html.LabelFor()。使用强类型辅助方法,在View页面的最上方一定要用@model定义出这个View页面的参考数据模型,如果没有生命就无法正常使用强类型辅助方法。

Html.LabelFor(),输出

Html.TextBoxFor()

Html.TextAreaFor()

Html.PasswordFor()

Html.CheckBoxFor()

Html.RadioButtonFor()

Html.DropDownListFor(),输出

Html.ListBoxFor(),输出

Html.HiddenFor() ,生成HTML窗体的隐藏域。

Html.DisplayNameFor(),显示数据模型在Metadata定义的显示名称。

Html.DisplayTextFor(),显示数据模型的文字资料。

Html.ValidationMessageFor(),显示数据模型当输入验证失败时显示的错误信息。

Html.EditorFor(),用来输出表单域可编辑文本框。

 做一个例子,首页显示商品明细,点击添加商品链接,打开添加商品页面,输入信息可添加商品。商品的模型类和添加商品页面代码如下:

技术图片
技术图片
public class Product
    {
        public int Id { get; set; }

        [Required]
        [DisplayName("产品名称")]
        public string Name { get; set; }

        [MaxLength(200)]
        [DisplayName("产品说明")]
        public string Description { get; set; }

        [Required]
        public int UnitPrice { get; set; }
    }
技术图片
技术图片
技术图片
技术图片
@model MvcApplication1.Models.Product

@using(Html.BeginForm())
{
    @Html.ValidationSummary(true)

    
产品资讯
@Html.LabelFor(model=>model.Name)
@Html.TextBoxFor(model=>model.Name) @Html.ValidationMessageFor(model=>model.Name)
@Html.LabelFor(model=>model.Description)
@Html.TextAreaFor(model=>model.Description) @Html.ValidationMessageFor(model=>model.Description)

}
技术图片
技术图片

3.使用HTML辅助方法载入分部视图

       以往在ASP.NET Web form的开发经验中,对于User Control使用非常频繁,不但可以减少重复的代码,也利于将页面模块化,这个好用的概念也可以用在ASP.NET MVC中,只不过换了一个名字,称为“分部视图(Partial View)”。

(1)什么是分部视图

        从Partial View的字面上翻译,很容易了解它就是一个片段的View,因此,可以利用Partial View把部分的HTML或显示逻辑包装起来,方便重复引用。当你将建立出来的分部视图放置于View\Shared目录时,任何Controller下的Action或View都可以载入。公用的Parital View放在Views\Shared目录。

技术图片

       分部视图的应用范围相当广,因为是片段的HTML显示逻辑,因此,整体重复性高或某段HTML会共同出现在多个视图页面中的网页片段,利用分部视图来开发会是不错的选择,并且基于这个优点,Ajax技术所需要的片段View也就更适合使用分部视图。

(2)如何建立一个分部视图

       建立分部视图与建立视图的步骤一样,在项目的/Views/Shared目录上,单击鼠标右键,在弹出的快捷菜单中选择“添加”->“视图”命令。接着,选中“创建为分部视图”复选框即可。

      使用分部视图不一定需要建立相关的Action,因为它仅仅是片段的HTML,且调用时,也不会调用Action来执行。

(3)使用Html.Partial载入分部视图

  ASP.NET MVC的HTML辅助方法拥有一个专门的扩充方法来载入分部视图,称为Partial,可以让你在View中直接将分部视图的执行结果取回。

使用方式 使用范例
Partial(HtmlHelper, String)  Html.Partial("ajaxPage")
Partial(HtmlHelper, String, Object)   Html.Partial("ajaxPage", Model)
Partial(HtmlHelper, String, ViewDataDictionary)    Html.Partial("ajaxPage", ViewData["Model"])
Partial(HtmlHelper, String, Object, ViewDataDictionary) Html.Partial("ajaxPage", Model, ViewData["Model"])

 

  因分部视图是片段的,必须要选择一个完整的页面来将它载入。

例子1,分部视图OnlineUserCounter代码如下。

 

线上人数:88888

 

 在Home/Index视图中载入分部视图。

@Html.Partial("OnlineUserCounter")

 

       利用上述方式就能将分部视图载入,因为是直接的载入,因此,调用的页面若有传递数据也可以直接调用出来。

      在一个视图页面里,如果载入了多个分部视图,每个分部视图里也可以存取到原本页面的ViewData、TempData及Model等数据,也就代表着这些从Controller传入的数据模型可以共用于各个分部视图之间。

      不过,载入分部视图时,也可以通过Html.Partial辅助方法传入另一个Model数据,如此一来,就能让分部视图里与载入该视图页面时使用不同的模型数据,也可以把视图页面中的一部分数据当成分部视图页面中的数据。

      我们以AccountController的Login页面为例,这一页在登录失败时会传入上一页输入的数据,当从视图页面中载入另一个分部视图时,可以传入一个object类型的参数作为分部视图的模型数据,如下视图页面。

技术图片
技术图片
@model LoginModel
@{
    ViewBag.Title="登录";
}

@Html.Partila("LoginFail", (object)Model.UserName)
技术图片
技术图片

接着在/Views/Account目录下新增一个名为LoginFail的分部视图,其内容如下:

@model System.String
从视图页面传入的模型数据为:@Model

由上述范例可以知道,在一般视图页面中的Model与LoginFail这个分部视图里的Model已经是不同的东西了。

(4)使用Html.Action辅助方法,从控制器载入分部视图

       分部视图页面除了可以直接从视图页面载入外,也可以像一般视图页面一样从Controller中使用。如下OnlineUserCount这个动作方法就是利用Controller类型中的PartialView辅助方法来载入分部视图,而这种载入方式与用View辅助方法唯一的差别,仅在于它不会套用母版页面,其他则都完全相同。

public ActionResult OnlineUserCount()
{
    return PartialView();
}

 然后可以在视图页面利用Html.Action来载入这个Action的执行结果:

@Html.Action("OnlineUserCounter")

       通过Html.Action与Html.Partial载入分部视图结果是一样的,但载入的过程却差别很大。若使用Html.Partial载入分部视图是通过HtmlHelper直接读取*.cshtml文件,直接执行该视图并取得结果。若使用Html.Action的话,则会通过HtmlHelper对IIS再进行一次处理要求(通过Server.Execute方法),因此,使用Html.Action会重新执行一遍Controller的生命周期。

 

原文链接:https://www.cnblogs.com/yytesting/p/4987633.html

MVC HTML辅助方法

标签:rop   过程   命名方式   错误   strong   net   帮助   online   因此   

原文地址:https://www.cnblogs.com/wfy680/p/12229375.html


评论


亲,登录后才可以留言!