在asp.net2.0的网页开发模式下,我们一般通过直将访问页面控件, 将值写入到页面, 但在Asp.net MVC模式下,已不能在Controller中再去访问页面控件了,要如何才能给View页面传值呢?在Controller中有两个字典(ViewData和TempData)来实现View之间的值传递,Controller通过ViewData,TempData传通到ViewResult中, 然后再由ViewResult传递到ViewPage中来实现值传递的。
1.TempData和ViewData的应用
ViewData只对当前Action有效,而TempData有点类似于Session, 可在所有View访问, 一般用于记录错误信息.
Action代码:
- publicActionResultIndex()
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- returnView();
- }
- publicActionResultIndex()
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- returnView();
- }
页面代码:
<h2><%=Html.Encode(ViewData["Message"])%></h2>
TempData使用方式与View使用方式一致.
<h2><%=Html.Encode(ViewData["Message"])%></h2>
2. ViewData与TextBox实现自动绑定
利用HtmlHelper创建TextBox时,使用名称与ViewData中的Key一致, 就会自动实现值绑定,如:
Name:<%=Html.TextBox("name")%>
名称不相同的情况下,也可以利用TextBox的重载传值:
Name:<%=Html.TextBox("name",ViewData["Nm"])%>
Name:<%=Html.TextBox("name",ViewData["Nm"])%>
3.View向Controller传值
1). 利用Action参数
- <formname="form1"action="/Home/Index"method="post">
- Name:<inputtype="text"name="name"/><br/>
- Sex:<inputtype="text"name="sex"/>
- <inputtype="submit"value="submit"/>
- </form>
- <%
- if(ViewData["name"]!=null)
- {
- Response.Write("yournameis:"+ViewData["name"]+",yoursexis:"+ViewData["sex"]);
- }
- %>
- :
- publicActionResultIndex(stringname,stringsex)
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- ViewData["name"]=name;
- ViewData["sex"]=sex;
- returnView();
- }
- <formname="form1"action="/Home/Index"method="post">
- Name:<inputtype="text"name="name"/><br/>
- Sex:<inputtype="text"name="sex"/>
- <inputtype="submit"value="submit"/>
- </form>
- <%
- if(ViewData["name"]!=null)
- {
- Response.Write("yournameis:"+ViewData["name"]+",yoursexis:"+ViewData["sex"]);
- }
- %>
- :
- publicActionResultIndex(stringname,stringsex)
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- ViewData["name"]=name;
- ViewData["sex"]=sex;
- returnView();
- }
- 2).利用Request.From或Request.QueryString
- 2).利用Request.From或Request.QueryString
- publicActionResultIndex()
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- ViewData["name"]=Request.Form["name"];
- ViewData["sex"]=Request.Form["sex"];
- returnView();
- }
- publicActionResultIndex()
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- ViewData["name"]=Request.Form["name"];
- ViewData["sex"]=Request.Form["sex"];
- returnView();
- }
3). 利用FormCollection获取页面值
- publicActionResultIndex(FormCollectionform)
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- Useru=newUser();
- u.Name=form["Name"];
- u.Password=form["Password"];
- returnView(u);
- }
- publicActionResultIndex(FormCollectionform)
- {
- ViewData["Message"]="WelcometoASP.NETMVC!";
- Useru=newUser();
- u.Name=form["Name"];
- u.Password=form["Password"];
- returnView(u);
- }
4.传递强类型
1).添加一个传递强类型Model的Action
- publicActionResultModelDemo()
- {
- Useru=newUser(){UserName="li",Password="abcde"};
- returnView(u);
- }
- publicActionResultModelDemo()
- {
- Useru=newUser(){UserName="li",Password="abcde"};
- returnView(u);
- }
对应的View也需要继随于ViewPage<User>, 对应代码如下:
- <p>
- <%Useru=(User)ViewData.Model;%>
- UserName:
- <%=Html.Encode(u.UserName)%>
- </p>
- <p>
- Password:
- <%=Html.Encode(u.Password)%>
- </p>
- <p>
- <%Useru=(User)ViewData.Model;%>
- UserName:
- <%=Html.Encode(u.UserName)%>
- </p>
- <p>
- Password:
- <%=Html.Encode(u.Password)%>
- </p>