ASP.NET MVC2中Controller向View传递数据的三种方式

转自:http://www.cnblogs.com/zhuqil/archive/2010/08/03/Passing-Data-from-Controllers-to-View.html

在Asp.net mvc开发中,Controller需要向View提供Model,然后View将此Model渲染成HTML。这篇文章介绍三种由Controller向View传递数据的方式,实现一个DropDownList的显示。

第一种:ViewData

ViewData是一个Dictionary。使用非常简单,看下面代码:

1 public ActionResult ViewDataWay(int id)
2 {
3 Book book =bookRepository.GetBook(id);
4 ViewData["Countries"] = new SelectList(PhoneValidator.Countries, book.Country);
5 return View(book);
6 }

在View中使用下面代码取值:

1 <div class="editor-field">
2 <%= Html.DropDownList("Country", ViewData["Countries"] as SelectList) %>
3 <%: Html.ValidationMessageFor(model => model.Country) %>
4 </div>

上面代码使用as将它转换成SelectList。

处理POST代码如下:

1 [HttpPost]
2 public ActionResult ViewDataWay(int id, FormCollection collection)
3 {
4 Book book = bookRepository.GetBook(id);
5 UpdateModel<Book>(book);
6 bookRepository.Save(book);
7 return RedirectToAction("Details", new { id=id});
8 }

效果:

第二种:ViewModel

使用ViewModel的方式,我们先创建一个BookViewModel,代码如下:

1 public class BookViewModel
2 {
3 public Book Book
4 {
5 get;
6 set;
7 }
8
9 public SelectList Countries
10 {
11 get;
12 set;
13 }
14 public BookViewModel(Book book)
15 {
16 Book = book;
17 Countries = new SelectList(PhoneValidator.Countries,book.Country);
18 }
19 }

在控制器的Aciton使用ViewModel存放数据的代码如下:

1 public ActionResult ViewModelWay(int id)
2 {
3 Book book = bookRepository.GetBook(id);
4 return View(new BookViewModel(book));
5 }

在View中,这种方式比第一种方式好在:它支持智能感应。

效果和第一种方式一样。

第三种:TempData

使用TempData和使用ViewData方法是一样的。

Action代码如下:

1 public ActionResult TempDataWay(int id)
2 {
3 Book book = bookRepository.GetBook(id);
4 TempData["Countries"] = new SelectList(PhoneValidator.Countries, book.Country);
5 return View(book);
6 }

View取值的代码如下:

1 <div class="editor-field">
2 <%= Html.DropDownList("Country", TempData["Countries"] as SelectList) %>
3 <%: Html.ValidationMessageFor(model => model.Country) %>
4 </div>

效果:第一种方式一样。

TempData和ViewData的区别

做个简单的测试看下看下TempData和ViewData的区别

1
2 public ActionResult Test1()
3 {
4
5 TempData["text"] = "1-2-3";
6 ViewData["text"] = "1-2-3";
7 return RedirectToAction("Test2");
8
9
10 }
11
12
13 public ActionResult Test2()
14 {
15
16 string text1 = TempData["text"] as string;
17 string text2 = ViewData["text"] as string;
18 return View();
19
20 }

看下面截图,发现经过Test1经过RedirectToAction跳转Test2后,ViewData的值已经被清空,而TempData没有被清空,这是它们的区别之一,我们可以用TempData在Controller之间传递数据。

关于TempData和ViewData的区别,发现网上大部分说法感觉都不对,网上有种说法:

1、TempData的数据至多只能经过一次Controller传递, 并且每个元素至多只能被访问一次

2、TempData中的元素被访问一次以后就会被删除。

我试一下,发现TempData和ViewData都只会在一次请求中有效,在第二次请求的时候都失效。而TempData可以在在一次请求中的多个Controller之间传递数据,而ViewData却不行,上图能证明。TempData也可多次访问。应该是说MVC在请求周期结束的时候有动作去删除此类的Session,而不是访问一次就被删除。MS命名为TempData,意思应该是说TempData是个Session,但是它又和普通的Session不同。它会在请求之后被删除,所以是临时的Data。

时间: 2024-10-06 21:49:05

ASP.NET MVC2中Controller向View传递数据的三种方式的相关文章

(四)ASP.NET MVC 中 Controller 给 View 传递数据的方式

1. ViewData: 以 ViewData["keyname"] = value 这样键值对的方式进行数据传送.在对应的 cshtml 中用 @ViewData["keyname"] 来获取值. 2. ViewBag: ViewBag 是 dynamic 类型的,是对 ViewData 的一人动态类型封装,用起来更方便,和 ViewData 共同操作一个数据 .在 Controller 中使用 ViewBag.keyname=value 来赋值,在 cshtml

在ASP.NET MVC中使用Unity进行依赖注入的三种方式

在ASP.NET MVC4中,为了在解开Controller和Model的耦合,我们通常需要在Controller激活系统中引入IoC,用于处理用户请求的 Controller,让Controller依赖于ModelRepository的抽象而不是它的实现. 我们可以在三个阶段使用IoC实现上面所说的解耦操作,首先需要简单介绍一下默认情况下Controller的激活过程: 1.用户发送请求黑ASP.NET,路由系统对请求进行解析,根据注册的路由规则对请求进行匹配,解析出Controller和Ac

ASP.NET MVC中Controller与View之间的数据传递

一.Controller向View传递数据 Controller向View传递数据有3种形式: 1.通过ViewData传递 在Controller里面定义ViewData,并且赋值,比如 ViewData["contact"] = contact; 然后在View里面读取Controller中定义的ViewData数据 比如联系人: <input type="text" value='<%=ViewData["contact"] %

ASP.NET MVC3中Controller与View之间的数据传递

在ASP.NET MVC中,经常会在Controller与View之间传递数据,因此,熟练.灵活的掌握这两层之间的数据传递方法就非常重要.本文从两个方面进行探讨: 一.  Controller向View传递数据 1.       使用ViewData传递数据 我们在Controller中定义如下: [csharp] view plain copy print? ViewData["Message_ViewData"] = " Hello ViewData!"; Vi

ASP.NET MVC中Controller与View之间的数据传递总结

在ASP.NET MVC中,经常会在Controller与View之间传递数据,因此,熟练.灵活的掌握这两层之间的数据传递方法就非常重要.本文从两个方面进行探讨: Ø Controller向View传递数据 Ø View向Controller传递数据 一.Controller向View传递数据 1.       使用ViewData传递数据 我们在Controller中定义如下: ViewData[“Message”] = “Hello word!”; 然后在View中读取Controller中

MVC中Controller与View之间数据互传

转自:http://blog.csdn.net/sknice/article/details/42323791 在ASP.NET MVC中,经常会在Controller与View之间传递数据,因此,熟练.灵活的掌握这两层之间的数据传递方法就非常重要.本文从两个方面进行探讨: 一.Controller向View传递数据 1.使用ViewData传递数据 在Controller中定义如下: ViewData[“Message_ViewData”] = “ Hello ViewData!”; 在Vie

EF5(7) 后台使用SelectListItem传值给前台显示Select下拉框;mvc后台Action接收浏览器传值的4种方式; 后台Action向前台View视图传递数据的四种方式

一:后台使用SelectListItem 传值给前台显示Select下拉框 我们先来看数据库的订单表,里面有3条订单,他们的用户id对应了 UserInfo用户表的数据,现在我们要做的是添加一个Order控制器,显示订单列表,并且在修改订单的时候,把用户的id 用 select 下拉框显示出来,并且可以提交修改数据   1.1 我们通过比较原始的方法,来把数据 传递到前台后,前台使用  循环来显示 select 并且显示是哪个元素被选中 我们在前台的cshtml中,使用 @model 命令 指定

Android学习笔记(十二)——使用意图传递数据的几种方式

使用意图传递数据的几种方式 点此获取完整代码 我们除了要从活动返回数据,也常常要传递数据给活动.对此我们可以使用Intent对象将这些数据传递给目标活动. 1.创建一个名为PassingData的项目,在activity_main.xml文件中添加一个Button: <Button android:id="@+id/btn_SecondActivity" android:layout_width="fill_parent" android:layout_hei

react之传递数据的几种方式props传值、路由传值、状态提升、redux、context

react之传递数据的几种方式 1.父子传值 父传值:<子的标签 value={'aaa'} index={'bbb'}></子的标签> 子接值:<li key={this.props.index}>{this.props.value}</li> 不止可以传值也可以传递方法: 父:方法={this.方法} 子:{this.props.方法.bind(this)} 传来的参数子组件可以使用,此处用{value,index}等解构赋值省去this.props 此