mvc中html控件⽤法
许多时候我们会遇到如下场景在写⼀个编辑数据的页⾯时,我们通常会写如下代码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:<ahref="/">这是⼀个连接</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:<ahref="/?page=1">这是⼀个连接</a>
3:<ahref="/?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,我们可以通过以下两种⽅式⽣成⼀个For
m: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.Text
Box("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" type="text"value="Beverages" />
<input id="input3" name="input3" type="text"value="" />
<input id="CategoryName" name="CategoryName" 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.L istBox
<%=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>
textarea中cols表示
<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"); %>  看清楚了没有等号的。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。