ASP.NET MVC HtmlHelper

,ASP.NET MVC提供了一个HtmlHelper用于生成有数据绑定的Html标签。javascript

1.ActionLink
其中最经常使用的就是Html.ActionLinkhtml

(1).ActionLink(string linkText, string actionName)java

//页面显示linkText指向Global.asax.cs中默认的Controller对象的actionName方法数据库

(2).ActionLink(string linkText, string actionName, string controllerName)数组

//页面显示linkText指向controllerName对应的Controller的actionName方法url

(3).ActionLink(string linkText,string actionName,object routues,object htmlAttributes)orm

//页面显示linkText指向Global.asax.cs中默认的Controller对象的actionName方法,而且传递参数给action方法(以匿名类型的名称/值对的方式来实现),并设置页面连接的属性htmlAttributes。htm

1.1基本的使用方式
在UrlRouting规则为默认规则的状况下,它生成的HTML代码为对象

1: <a href="/">这是一个链接</a>ip

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: <a href="/?Length=4" id="link1">这是一个链接</a>
6: <a href="/" id="link1">这是一个链接</a>
7: QueryString与Html属性同时存在
8: <a href="/?page=1" id="link1">这是一个链接</a>
9: <a href="/?page=1" id="link1">这是一个链接</a>

这样就能够使用ActionLink生成近乎全部的地址链接了。

注意,若是链接中不涉及到action及controller就没有必要使用ActionLink,而是直接写HTML代码就能够了,例如

1: <a href="#1">一章</a>
2: <a href="javascript:void(0)" onclick="delete();">删除</a>

2.RouteLink
2.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" })%>

就能够这样来写

其实就是用一个新创建的RoutueDictionary的对象(new{}所实例化的对象将会等价转换为RoutueDictionary)来替原来的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: <a href="/about">关于</a>
2: <a href="/about?page=1">关于</a>
3: <a href="/about?page=1" id="link1">关于</a>

3.表单
不少状况下是要生成表单元素的,正如文章开始所述,修改一个内容的状况下,咱们可能要将数据与表单绑定。

3.1生成Form
咱们固然能够使用纯的Html代码或UrlHelper来生成一个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:  );

相关文章
相关标签/搜索