ASP.NET中MVC传递数据的几种形式总结

本文实例讲述了ASP.NET中MVC传递数据的几种形式。分享给大家供大家参考。具体如下:

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

第一种:ViewData

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

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

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

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

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

处理POST代码如下:

[HttpPost]
public ActionResult ViewDataWay(int id, FormCollection collection)
{
  Book book = bookRepository.GetBook(id);
  UpdateModel<Book>(book);
  bookRepository.Save(book);
  return RedirectToAction("Details", new { id=id});
}

第二种:ViewModel

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

public class BookViewModel
{
 public Book Book
 {
   get;
   set;
 }
 public SelectList Countries
 {
   get;
   set;
 }
 public BookViewModel(Book book)
 {
   Book = book;
  Countries = new SelectList(PhoneValidator.Countries,book.Country);
 }
}

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

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

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

效果和第一种方式一样。

第三种:TempData

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

Action代码如下:

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

View取值的代码如下:

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

效果:第一种方式一样。

TempData和ViewData的区别

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

public ActionResult Test1()
{
  TempData["text"] = "1-2-3";
   ViewData["text"] = "1-2-3";
   return RedirectToAction("Test2");
}
public ActionResult Test2()
{
   string text1 = TempData["text"] as string;
  string text2 = ViewData["text"] as string;
   return View();
}

RedirectToAction跳转Action后,ViewData的值已经被清空,而TempData没有被清空,这是它们的区别之一。

希望本文所述对大家的asp.net程序设计有所帮助。

(0)

相关推荐

  • Spring MVC 学习 之 - URL参数传递详解

    在学习 Spring Mvc 过程中,有必要来先了解几个关键参数: @Controller: 在类上注解,则此类将编程一个控制器,在项目启动 Spring 将自动扫描此类,并进行对应URL路由映射. @Controller public class UserAction{ } @RequestMapping 指定URL映射路径,如果在控制器上配置 RequestMapping  ,具体请求方法也配置路径则映射的路径为两者路径的叠加 常用映射如:RequestMapping("url.html&q

  • MVC页面之间参数传递解析

    关于MVC页面之间的传值,有多种方式,下面,我们就Html.RenderAction 方式 和 Html.RenderPartial 方式 来给大家分享一下有什么不同. 一.Html.RenderAction 方式页面之间传递参数的方式: Html.RenderAction 方式 是访问的另一页面的Controller,并将参数传入另一页面的Controller中相应的Action中的参数中. 例如:我有这么一个Controller和Action(是一个部分视图的) public class T

  • ASP.NET中MVC从后台控制器传递数据到前台视图的方式

    本文实例讲述了ASP.NET中MVC从后台控制器传递数据到前台视图的方式.分享给大家供大家参考.具体分析如下: 数据存储模型Model: 复制代码 代码如下: public class CalendarEvent { public string id { get; set; } public DateTime start { get; set; } public DateTime end { get; set; } public string backgroundColor { get; set

  • 使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇

    调用jQuery的ajax方法时,jQuery会根据post或者get协议对参数data进行序列化; 如果提交的数据使用复杂的json数据,例如: {userId:32323,userName:{firstName:"李",lastName:"李大嘴"}} 那么服务器是无法正常接收到完整的参数,因为jQuery对data的序列化,是使用了键值对拼装的方式; 参数拼装成 userId=32323&userName=object ; userName所指向的对象

  • Ruby on Rails中MVC结构的数据传递解析

    如果读者已经开发过基于 Rails 的应用,但对其 MVC 间的数据传递还有诸多困惑,那么恭喜您,本文正是要总结梳理 Rails 数据传递的方法和技巧.Ruby on Rails 3(以下统称为 Rails 3)是当前的主要发布版本,本文所述及的内容和代码都基于此版本. Rails 3 简介 Ruby on Rails 是一个 Ruby 实现.采用 MVC 模式的开源 Web 应用开发框架,能够提供 Web 应用的全套解决方案.它的"习惯约定优于配置"的设计哲理,使得 Web 开发人员

  • springMVC框架下JQuery传递并解析Json数据

    json作为一种轻量级的数据交换格式,在前后台数据交换中占据着非常重要的地位.Json的语法非常简单,采用的是键值对表示形式. JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序,也可以从服务器端程序传递json格式的字符串给前端并由前端解释.这个字符串是符合json语法的,而json语法又是javascript语法的子集,所以javascript很容易解释它,而且

  • jsp 显示springmvc modelmap传递的对象详细介绍

    jsp 显示springmvc modelmap传递的对象 最近在做一个小网站,功能非常基础,决定用springmvc搭建. 遇到一个问题,在controller向前端传值时,比如使用ModelMap传了一个字符串,modelmap.addattribute("msg", "hello"),那么在jsp端,直接使用${msg}就可以显示.接着,如果我传递了一个对象,依然可以使用${obj.name}这样的方法来显示该对象的各个属性.然而更多情况下,都需要显示列表,所

  • SpringMVC实现前端后台交互传递数据

    本人对springmvc前端交互不太懂,搜索了很多关于springmvc前端交互介绍,下面我来记录一下,有需要了解的朋友可参考.希望此文章对各位有所帮助. Controller.java代码: @Controller public class DataController { //一.接收和通过ModelMap传出参数,不需要视图解析器,测试时加了解析器,顾返回值不需后缀 //普通参数 @RequestMapping("/data1") public String data1(@Req

  • ASP.NET MVC从控制器传递数据到视图的四种方式详解

    前奏 1. 在新建项目中的Models文件下,新建Products类: public class Products { public int Id { get; set; } public string Name { get; set; } public double Price { get; set; } } 2. 在控制器中实例化此类 var p = new Products() { Id = 1, Name = "饮料", Price = 2.5 }; 方式1:ViewData

  • SpringMVC框架下JQuery传递并解析Json格式的数据是如何实现的

    json作为一种轻量级的数据交换格式,在前后台数据交换中占据着非常重要的地位.Json的语法非常简单,采用的是键值对表示形式.JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序,也可以从服务器端程序传递json格式的字符串给前端并由前端解释.这个字符串是符合json语法的,而json语法又是 javascript语法的子集,所以javascript很容易解释它,而且

随机推荐