许多时候我们会遇到如下场景在写一个编辑数据的页面时,我们通常会写如下代码1:<inputtype ="text" value='<%=ViewData["title"] %>' name="title" />由前篇我们所讲的Helper演化,我们思考,对于这种代码我们是不是也可以用一个Helper来自动绑定数据呢这当然是可以的,ASP.NET MVC提供了一个HtmlHelper用于生成有数据绑定的Html标签。

1.ActionLink

其中最常用的就是Html.ActionLink
1.1基本的使用方式
1: <%=Html.ActionLink("页面显示的文字", "Index", "Home")%>
在UrlRouting规则为默认规则的情况下,它生成的HTML代码为1:
<a href="/">页面显示的文字</a> ActionLink中的三个参数分别为 (显示的文字 Action Controller)
其中Controller可以省略,省略时指向同一Controller下的Action。

1.2ActionLink中QueryString与Html属性设置
1: 带有QueryString的写法
2: <%=Html.ActionLink("页面显示的文字", "Index", "Home", new { page=1 },null)%>
3:<%=Html.ActionLink("页面显示的文字", "Index", new { page=1 })%>
4: 有其它Html属性的写法
5: <%=Html.ActionLink("页面显示的文字", "Index", "Home", new { id="link1" })%>
6: <%=Html.ActionLink("页面显示的文字", "Index",null, new { id="link1" })%>
7: QueryString与Html属性同时存在
8: <%=Html.ActionLink("页面显示的文字", "Index", "Home", new { page = 1 }, new { id = "link1" })%>
9: <%=Html.ActionLink("页面显示的文字","Index" , new { page = 1 }, new { id = "link1" })%>
其生成结果为:1: 带有QueryString的写法
2:<a href="/?page=1">页面显示的文字</a>
3:<a href="/?page=1">页面显示的文字</a>
4: 有其它Html属性的写法
5:<ahref ="/?Length=4" id="link1">
页面显示的文字</a>
6:<ahref ="/" id="link1">
页面显示的文字</a>
7: QueryString与Html属性同时存在
8:<ahref ="/?page=1" id="link1">
页面显示的文字</a>
9:<ahref ="/?page=1" id="link1">
页面显示的文字</a>
这样就可以使用ActionLink生成近乎所有的地址连接了。注意,如果连接中不涉及到action及controller就没有必要使用ActionLink,而是直接写HTML代码就可以了,
例如1:<ahref ="#1">
一章</a> 2:<ahref ="javascript:void(0)" onclick="delete();">
删除</a>

2.RouteLink2.1与ActionLink
RouteLink与ActionLink相差无几,只是它的地址是由Route生成拿上面的例子
1: <%=Html.ActionLink("页面显示的文字", "Index", "Home")%> 来说,
如果用RouteLink来写就是
1: <%=Html.RouteLink("页面显示的文字", new { controller="Home",action="Index"})%>
而带上QueryString以及Html属性的ActionLink
1: <%=Html.ActionLink("页面显示的文字", "Index" , new { page = 1 }, new { id ="link1" })%>
就可以这样来写1: <%=Html.RouteLink("页面显示的文字", new { action = "index", page = 1 }, new { id="link1"})%>
其实就是用一个新建立的RouteValueDictionary的对象(new{}所实例化的对象将会等价转换为RouteValueDictionary)来替原来的Action,Controller字符串的单独指定。

2.2RouteLink使用Route规则
除了这些协同的用法,RouteLink还支持使用Route规则名来创建连接例如我们在Global.asax文件中添加一个Route规则1: routes.MapRoute( 2:"about",//这是规则名 3:"about",//url 4:new {controller = "Home", action = "about"} 5: ); 那么我们就可以使用这个Route规则1: <%=Html.RouteLink("关于", "about", new { })%> 2: <%=Html.RouteLink("关于", "about", new { page = 1 })%> 3: <%=Html.RouteLink("关于", "about", new { page = 1 }, new { id = "link1" })%>来生成如下的HTML:1:<ahref ="/about">
关于</a> 2:<ahref ="/about?page=1">
关于</a> 3:<ahref ="/about?page=1" id="link1">
关于</a>
3.表单

很多情况下是要生成表单元素的,正如文章开始所述,修改一个内容的情况下,我们可能要将数据与表单绑定。
3.1生成Form

我们当然可以使用纯的Html代码或UrlHelper来生成一个Form。如1:<formaction ="/home/index" method="post">
2:</form>1:<formaction ="<%=Url.Action(" index","home")%>
"method="post"> 2:</form>但是因为是在HTML的属性中,所以还是难以维护,幸好ASP.NET MVC为我们提供了一个Helper,我们可以通过以下两种方式生成一个Form:1: <%using(Html.BeginForm("index","home",FormMethod.Post)){%> 2: 表单内容 3: <%} %> 4: <%Html.BeginForm("index", "home", FormMethod.Post);//注意这里没有=输出%> 5: 表单内容 6: <%Html.EndForm(); %>BeginForm方法类似于ActionLink的调用方式,所以ASP.NET MVC还提供了BeginRouteForm这种方法。当然这里我们也可以使用new{}来为form的action增加querystring或HTML属性,方法与前面介绍的大同小异,参见方法列表即可。
3.2表单元素

ASP.NET MVC提供了多种表单元素的Helper。其中包括:TextBox(类似input type=text,下面类似)、TextArea、DropDownList(select)、CheckBoxHidden、ListBox、Password、RadionButton。注意:因为<input type=”submit” />一般情况下是不会绑定数据的所以ASP.NET MVC并未提供此Helper(曾经提供过在preview2之前)。如果我们想提供一个input type=text 它的name为t1则以下代码:1: <%=Html.TextBox("t1") %>
3.3表单元素绑定

如果我们想要让上文中的t1初始时就有一个值,比如 “重典”那么我们可以按以下方式1: <%=Html.TextBox("t1","重典") %>如果数据是从数据库中读取,即得到数据是从Action中获取的,那么我们可以在Action中使用ViewData传递Action:1: ViewData["name"]="重典";View:1: <%=Html.TextBox("t1",ViewData["name"]) %>以上方法看似简单,其实ASP.NET MVC为我们提供了更为简便的绑定方式---只要保证ViewData的Key与Helper所生成元素的name保持一致就可以自动绑定:Action:1: ViewData["t1"]="重典";View:1: <%=Html.TextBox("t1") %>这样就可以自动绑定了
3.4列表数据显示与绑定

像TextBox这种值单一的数据比较容易,但是存在的数据比较多的DropDownList或ListBox应该怎么绑定数据及初始化值呢,我们来看看下面的例子:Action:1: ViewData["sel1"] = new SelectList( 2:new[] {1, 2, 3} /*列表内容可以是数组*/ 3: , 3 /*默认值,可以是从数据库读出的*/ 4: );View:1: <%=Html.DropDownList("sel1")%>这样就可以将列表内容、默认值、以及表单元素三者绑定在一起了。而我们的列表内容并不是任何情况下都是数组的,大多情况下还是Key-Value对居多。我们可以使用以下方式:
1: List<selectlistitem>
list = new List<selectlistitem>

2: {

3:new SelectListItem {Text = "重典", Value = "1"},

4:new SelectListItem {Text = "邹健", Value = "2"},

5: };

6: ViewData["sel1"] = new SelectList(

7: list /*列表内容可以是数组*/

8: , "2"/*默认值,可以是从数据库读出的*/

9:

);

10.TextBox , Hidden

<%=Html.TextBox("input1") %>

<%=Html.TextBox("input2",Model.CategoryName,new{ @style = "width:300px;" }) %>

<%=Html.TextBox("input3", ViewData["Name"],new{ @style = "width:300px;" }) %>

<%=Html.TextBoxFor(a => a.CategoryName, new { @style = "width:300px;" })%>

生成结果:

<input id="input1" name="input1" type="text" value="" />

<input id="input2" name="input2" style="width:300px;" type="text" value="Beverages" />

<input id="input3" name="input3" style="width:300px;" type="text" value="" />

<input id="CategoryName" name="CategoryName" style="width:300px;" type="text" value="Beverages" />

‍‍‍‍‍11.TextArea

‍‍<%=Html.TextArea("input5", Model.CategoryName, 3, 9,null)%>

<%=Html.TextAreaFor(a => a.CategoryName, 3, 3, null)%>

生成结果:

<textarea cols="9" id="input5" name="input5" rows="3">Beverages</textarea>‍

<textarea cols="3" id="CategoryName" name="CategoryName" rows="3">Beverages</textarea>

12.CheckBox

<%=Html.CheckBox("chk1",true) %>

<%=Html.CheckBox("chk1", new { @class="checkBox"}) %>

<%=Html.CheckBoxFor(a =>a.IsVaild, new { @class = "checkBox" })%>

生成结果:

<input checked="checked" id="chk1" name="chk1" type="checkbox" value="true" />

<input name="chk1" type="hidden" value="false" />‍

<input class="checkBox" id="chk1" name="chk1" type="checkbox" value="true" />

<input name="chk1" type="hidden" value="false" />

<input checked="checked" class="checkBox" id="IsVaild" name="IsVaild" type="checkbox" value="true" />

<input name="IsVaild" type="hidden" value="false" />

‍13.‍ListBox

<%=Html.ListBox("lstBox1",(SelectList)ViewData["Categories"])%>‍

<%=Html.ListBoxFor(a => a.CategoryName, (SelectList)ViewData["Categories"])%>‍

生成结果:

<select id="lstBox1" multiple="multiple" name="lstBox1">

<option value="1">Beverages</option>‍

<option value="2">Condiments</option>

<option selected="selected" value="3">Confections</option>‍

<option value="4">Dairy Products</option>

<option value="5">Grains/Cereals</option>‍

<option value="6">Meat/Poultry</option>

<option value="7">Produce</option>‍

<option value="8">Seafood</option>‍

</select>

<select id="CategoryName" multiple="multiple" name="CategoryName">

<option value="1">Beverages</option>

<option value="2">Condiments</option>‍

<option value="3">Confections</option>

<option value="4">Dairy Products</option>

<option value="5">Grains/Cereals</option>‍

<option value="6">Meat/Poultry</option>

<option value="7">Produce</option>‍

<option value="8">Seafood</option>

</select>

14.DropDownList

‍<%= Html.DropDownList("ddl1", (SelectList)ViewData["Categories"], "--Select One--")%>‍

<%=Html.DropDownListFor(a => a.CategoryName, (SelectList)ViewData["Categories"], "--Select One--", new { @class = "dropdownlist" })%>

生成结果:

<select id="ddl1" name="ddl1">

<option value="">--Select One--</option>‍

<option value="1">Beverages</option>‍

<option value="2">Condiments</option>

<option selected="selected" value="3">Confections</option>

<option value="4">Dairy Products</option>

<option value="5">Grains/Cereals</option>‍

<option value="6">Meat/Poultry</option>

<option value="7">Produce</option>‍

<option value="8">Seafood</option>‍

</select>

<select class="dropdownlist" id="CategoryName" name="CategoryName">

<option value="">--Select One--</option>

<option value="1">Beverages</option>‍

<option value="2">Condiments</option>

<option value="3">Confections</option>‍

<option value="4">Dairy Products</option>

<option value="5">Grains/Cereals</option>

<option value="6">Meat/Poultry</option>

<option value="7">Produce</option>‍

<option value="8">Seafood</option>

</select>‍

15.Partial 视图模板

webform里叫自定义控件。功能都是为了复用。但使用上自定义控件真的很难用好。

<% Html.RenderPartial("DinnerForm"); %>  看清楚了没有等号的,也就是同目录下,不需要指定 .cshtml 扩展名
还可以这样:
@HtmlRederPartial("~/Views/Share/_myLogin.cshtml");  //这样操作的话就要指定扩展名(.cshtml)

HtmlHelper使用大全的更多相关文章

  1. MVC5 + EF6 + Bootstrap3 (9) HtmlHelper用法大全(下)

    文章来源:Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc5-ef6-bs3-get-started-httphelper-part2.html 上一节 ...

  2. MVC5 + EF6 + Bootstrap3 (8) HtmlHelper用法大全(上)

    文章来源:Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc5-ef6-bs3-get-started-httphelper-part1.html 上一节 ...

  3. MVC HtmlHelper用法大全

    MVC HtmlHelper用法大全HtmlHelper用来在视图中呈现 HTML 控件.以下列表显示了当前可用的一些 HTML 帮助器. 本主题演示所列出的带有星号 (*) 的帮助器. ·Actio ...

  4. MVC中HtmlHelper用法大全参考

    MVC中HtmlHelper用法大全参考 解析MVC中HtmlHelper控件7个大类中各个控件的主要使用方法(1) 2012-02-27 16:25 HtmlHelper类在命令System.Web ...

  5. HtmlHelper用法大全

    HTML扩展类的所有方法都有2个参数: 以textbox为例子 public static string TextBox( this HtmlHelper htmlHelper, string nam ...

  6. C# ASP.NET MVC HtmlHelper用法大全

    UrlHrlper 下面的两个地址一样的功能 下边这个防止路由规则改变 比如UserInfo/Index改为UserInfo-Index,使用下面的不受影响 另一种形式的超链接: <%: Htm ...

  7. ASP.NET MVC HtmlHelper用法大全

    HTML扩展类的所有方法都有2个参数: 以textbox为例子public static string TextBox( this HtmlHelper htmlHelper, string name ...

  8. 【转】MVC HtmlHelper用法大全

    HtmlHelper用来在视图中呈现 HTML 控件. 以下列表显示了当前可用的一些 HTML 帮助器. 本主题演示所列出的带有星号 (*) 的帮助器. ActionLink - 链接到操作方法. B ...

  9. [转]MVC HtmlHelper用法大全

    原文链接:http://www.cnblogs.com/jyan/archive/2012/07/23/2604474.html HtmlHelper用来在视图中呈现 HTML 控件. 以下列表显示了 ...

随机推荐

  1. IIS发布网站遇到的异常

    1.0 HTTP 错误 401.3 - Unauthorized由于 Web 服务器上此资源的访问控制列表(ACL)配置或加密设置,您无权查看此目录或页面.详细错误信息模块 IIS Web Core通 ...

  2. RDLC报表打印

    如果你的报表能正常显示,会看到RDLC工具条下的打印图标: 如果在客户端,第一次去点击此铵钮,如果当前操作者没有管理权限,会提示: Unable to load client print contro ...

  3. iOS阶段学习第20天笔记(MRC内存管理)

    iOS学习(OC语言)知识点整理 一.OC中的内存管理 1)概念:内存管理的对象为所有继承了NSObject的对象,对基本数据(如:int .float.double...)无效      OC中采用 ...

  4. C#通用类Helper整理

    ★前言     最近下载了tita_chou在CSDN上传的一个资源,是在工作中整理的C#帮助类,里面包含了很多实用的类,想到我之前收集过自己用到少的可怜的类,心生敬意啊.当粗略的查看了那个资源,发现 ...

  5. 对Java并发编程的几点思考

    1. Threads 和 Runnables 所有的现代操作系统都通过进程和线程来支持并发.进程是通常彼此独立运行的程序的实例,比如,如果你启动了一个Java程序,操作系统产生一个新的进程,与其他程序 ...

  6. 利用PBFunc在Powerbuilder中支付宝当面付功能

    在PB实现支付宝当面付的功能,需要先在支付宝进行商户签约,并设置相关的公钥信息(具体参考支付宝文档). 然后使用对应的私钥文件对参数进RSAWithSha1前面计算.具体代码如下: string ls ...

  7. python 学习笔记7(装饰器)

    闭包(closure)是函数式编程的重要的语法结构. 定义:如果在一个内部函数里,对在外部作用域(但不是在全局作用域)的变量进行引用,那么内部函数就被认为是闭包(closure). def outer ...

  8. 六个创建模式之原型模式(Prototype Pattern)

    定义: 使用原型实例指定创建对象的种类,并通过拷贝这个原型的属性创建新的对象. 结构图: Prototype:抽象原型类,声明克隆方法的接口,并是所有原型类的公共父类.在Java中,Object类为该 ...

  9. java内存模型-顺序一致性

    数据竞争与顺序一致性保证 当程序未正确同步时,就会存在数据竞争.java 内存模型规范对数据竞争的定义如下: 在一个线程中写一个变量, 在另一个线程读同一个变量, 而且写和读没有通过同步来排序. 当代 ...

  10. Hyhyhy – 专业的 HTML5 演示文稿工具

    Hyhyhy 是创建好看的 HTML5 演示文档的工具.它具备很多的特点:支持 Markdown,嵌套幻灯片,数学排版,兼容性,语法高亮,使用 Javascript API ,方便的骨架.它支持 Fi ...