很多情况下是要生成表单元素的,正如文章开始所述,修改一个内容的情况下,我们可能要将数据与表单绑定。
3.1生成Form
我们当然可以使用纯的Html代码或UrlHelper来生成一个Form。
如
1: <form action="/home/index" method="post">
2: </form>
1: <form action="<%=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: );
网址: http://www.cnblogs.com/chsword/archive/2009/04/13/zd_mvc9.html