ASP.NET MVC学习笔记-Controller与View传值

在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代码:
[csharp] view plain copy
  1. public ActionResult Index()      
  2. {      
  3.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  4.     return View();      
  5. }     
[csharp] view plain copy
  1. public ActionResult Index()      
  2. {      
  3.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  4.     return View();      
  5. }     

页面代码:
      <h2><%= Html.Encode(ViewData["Message"]) %></h2>
TempData使用方式与View使用方式一致.


2. ViewData与TextBox实现自动绑定
利用HtmlHelper创建TextBox时,使用名称与ViewData中的Key一致, 就会自动实现值绑定,如:

    Name:<%= Html.TextBox("name") %> 

名称不相同的情况下,也可以利用TextBox的重载传值:
    Name:<%= Html.TextBox(
"name", ViewData["Nm"]) %>
 
3.View向Controller传值
1). 利用Action参数
[csharp] view plain copy
  1. <form name="form1" action="/Home/Index" method="post">      
  2.     Name:<input type="text" name="name" /><br />      
  3.     Sex: <input type="text" name="sex" />      
  4.     <input type="submit" value="submit" />      
  5. </form>      
  6. <%      
  7.     if (ViewData["name"] != null)      
  8.     {      
  9.         Response.Write("your name is:" + ViewData["name"] + ",  your sex is:" + ViewData["sex"]);      
  10.     }                 
  11. %>      
  12. :      
  13. public ActionResult Index(string name, string sex)      
  14. {      
  15.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  16.     ViewData["name"] = name;      
  17.     ViewData["sex"] = sex;      
  18.     return View();      
  19. }    
[csharp] view plain copy
  1. <form name="form1" action="/Home/Index" method="post">      
  2.     Name:<input type="text" name="name" /><br />      
  3.     Sex: <input type="text" name="sex" />      
  4.     <input type="submit" value="submit" />      
  5. </form>      
  6. <%      
  7.     if (ViewData["name"] != null)      
  8.     {      
  9.         Response.Write("your name is:" + ViewData["name"] + ",  your sex is:" + ViewData["sex"]);      
  10.     }                 
  11. %>      
  12. :      
  13. public ActionResult Index(string name, string sex)      
  14. {      
  15.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  16.     ViewData["name"] = name;      
  17.     ViewData["sex"] = sex;      
  18.     return View();      
  19. }    

[html] view plain copy
  1. 2).利用Request.From或Request.QueryString  
[html] view plain copy
  1. 2).利用Request.From或Request.QueryString  

[csharp] view plain copy
  1. public ActionResult Index()      
  2. {      
  3.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  4.     ViewData["name"] = Request.Form["name"];      
  5.     ViewData["sex"] = Request.Form["sex"];      
  6.     return View();      
  7. }   
[csharp] view plain copy
  1. public ActionResult Index()      
  2. {      
  3.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  4.     ViewData["name"] = Request.Form["name"];      
  5.     ViewData["sex"] = Request.Form["sex"];      
  6.     return View();      
  7. }   


3). 利用FormCollection获取页面值

[csharp] view plain copy
  1. public ActionResult Index(FormCollection form)      
  2. {      
  3.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  4.     User u=new User();      
  5.     u.Name = form["Name"];      
  6.     u.Password = form["Password"];      
  7.     return View(u);      
  8. }    
[csharp] view plain copy
  1. public ActionResult Index(FormCollection form)      
  2. {      
  3.     ViewData["Message"] = "Welcome to ASP.NET MVC!";      
  4.     User u=new User();      
  5.     u.Name = form["Name"];      
  6.     u.Password = form["Password"];      
  7.     return View(u);      
  8. }    

4.传递强类型
1).添加一个传递强类型Model的Action
[csharp] view plain copy
  1. public ActionResult ModelDemo()      
  2. {      
  3.     User u= new User() { UserName="li", Password="abcde" };      
  4.     return View(u);      
  5. }   
[csharp] view plain copy
  1. public ActionResult ModelDemo()      
  2. {      
  3.     User u= new User() { UserName="li", Password="abcde" };      
  4.     return View(u);      
  5. }   

对应的View也需要继随于ViewPage<User>, 对应代码如下:
[html] view plain copy
  1. <p>      
  2.    <%User u = (User)ViewData.Model;%>      
  3.    UserName:       
  4.    <%= Html.Encode(u.UserName) %>      
  5. </p>      
  6. <p>      
  7.     Password:       
  8.     <%= Html.Encode(u.Password) %>      
  9.  </p>    
[html] view plain copy
  1. <p>      
  2.    <%User u = (User)ViewData.Model;%>      
  3.    UserName:       
  4.    <%= Html.Encode(u.UserName) %>      
  5. </p>      
  6. <p>      
  7.     Password:       
  8.     <%= Html.Encode(u.Password) %>      
  9.  </p>   

你可能感兴趣的:(ASP.NET MVC学习笔记-Controller与View传值)