zoukankan      html  css  js  c++  java
  • Controller向View传递数据

    1.       使用ViewData传递数据

    我们在Controller中定义如下:

    ViewData[“Message”] = “Hello word!”;

    然后在View中读取Controller中定义的ViewData数据,代码如下:

    <% = Html.Encode(ViewData[“Message”]) %>

    2.       使用TempData传递数据

    我们在Controller中定义如下:

    TempData[“Message”] = “Hello word!”;

    然后在View中读取Controller中定义的TempData数据,代码如下:

    <% = Html.Encode(TempData [“Message”]) %>

    3.       使用Model传递数据

    使用Model传递数据的时候,通常在创建View的时候我们会选择创建强类型View如下图所示:

    创建强类型的View以后,View的第一行代码如下所示:

    <%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<MvcInduction.Models.People>" %>

    <MvcInduction.Models.People>就代表了这个View使用的Model为“MvcInduction.Models.People

    总结:

    1.         ViewData与TempData方式是弱类型的方式传递数据,而使用Model传递数据是强类型的方式。

    2.         ViewData与TempData是完全不同的数据类型,ViewData数据类型是ViewDataDictionary类的实例化对象,而TempData的数据类型是TempDataDictionary类的实例化对象。

    3.         TempData实际上保存在Session中,控制器每次执行请求时都会从Session中获取TempData数据并删除该Session。TempData数据只能在控制器中传递一次,其中的每个元素也只能被访问一次,访问之后会被自动删除。

    4.         ViewData只能在一个Action方法中进行设置,在相关的视图页面读取,只对当前视图有效。理论上,TempData应该可以在一个Action中设置,多个页面读取。但是,实际上TempData中的元素被访问一次以后就会被删除。

     

    4.       MVC3多出了ViewBag传递数据

     在Asp.net MVC 3 web应用程序中,我们会用到ViewDataViewBag,对比一下:

    ViewData ViewBag
    它是Key/Value字典集合 它是dynamic类型对像
    从Asp.net MVC 1 就有了 ASP.NET MVC3 才有
    基于Asp.net 3.5 framework 基于Asp.net 4.0与.net framework
    ViewData比ViewBag快 ViewBag比ViewData慢
    在ViewPage中查询数据时需要转换合适的类型 在ViewPage中查询数据时不需要类型转换
    有一些类型转换代码 可读性更好

    在Controller中使用ViewData:

    public ActionResult UsingViewData()
    {
        
        ViewData["Title"] = " Using ViewData";
        ViewData["ProjectName"] = "My Test Project";
        ViewData["ProjectDescription"] = "This is Test Project to demo Viewdata and viewbag details";
        ViewData["StartDate"] = new DateTime(2011, 1, 1);
        ViewData["TotalPrice"] = 1000;
        ViewData["TotalDays"] = 100;
        Dictionary<string, string> stackholder = new Dictionary<string, string>();
        stackholder.Add("Client","Mr.  Client");
        stackholder.Add("Manager","Mr. Joy");
        stackholder.Add("Team Leader","Mr.Toy");
        stackholder.Add("Sr. developer", "Mr.dojoy");
        stackholder.Add("developer", "Mr. nodoy");
        ViewData["stackholder"] = stackholder;
    
        List<string> modules = new List<string>();
        modules.Add("Admin module");
        modules.Add("ShoppingCart module");
        modules.Add("CMS module");
        ViewData["modules"] = modules;
        return View();
    }


    对应UsingViewData View的cshtml:

    <h1>@ViewData["Title"]</h1>
     <div>
       <div>
        <h2>Project Name : @ViewData["ProjectName"]</h2>
       </div>
       <div>
         ProjectDescription :   
         <p>"@ViewData["ProjectDescription"]".</p>
       </div>
       <div>
          Stack Holder :
          <br />
    
          <ul id="stakholder">
          @foreach ( var stakerholder in ViewData["stackholder"] as Dictionary<string, string> )
          {          
        <li>
            @stakerholder.Key &nbsp; : @stakerholder.Value
        </li>
          }
         </ul>
       </div>
       <div>
         Project Details:<br />
         <div>
           module List  :
           <ul id="modulelist">
          @foreach ( var module in ViewData["modules"] as List<string> )
          {          
        <li>
            @module
        </li>
          }
         </ul>
            
         </div>
         Project StartDate : @ViewData["StartDate"]  <br />
         Project TotalPrice: @ViewData["TotalPrice"] <br />
         Project TotaDays  : @ViewData["TotalDays"] 
       </div>
     </div>
    


    然后是ViewBag:

    public ActionResult UsingViewBag()
    {
    
        ViewBag.Title = " Using ViewBag";
        ViewBag.ProjectName = "My Test Project";
        ViewBag.ProjectDescription = "This is Test Project to demo Viewdata and viewbag details";
        ViewBag.StartDate = new DateTime(2011, 1, 1);
        ViewBag.TotalPrice = 1000;
        ViewBag.TotalDays = 100;
        Dictionary<string, string> stackholder = new Dictionary<string, string>();
        stackholder.Add("Client", "Mr.  Client");
        stackholder.Add("Manager", "Mr. Joy");
        stackholder.Add("Team Leader", "Mr.Toy");
        stackholder.Add("Sr. developer", "Mr.dojoy");
        stackholder.Add("developer", "Mr. nodoy");
        ViewBag.stackholder = stackholder;
    
        List<string> modules = new List<string>();
        modules.Add("Admin module");
        modules.Add("ShoppingCart module");
        modules.Add("CMS module");
        ViewBag.modules = modules;
        return View();
    }


    对应View UsingViewBag 的cshtml的ViewBag:

    <h1>@ViewBag.Title</h1>
     <div>
       <div>
        <h2>Project Name : @ViewBag.ProjectName</h2>
       </div>
       <div>
         ProjectDescription :   
         <p>"@ViewBag.ProjectDescription.</p>
       </div>
       <div>
          Stack Holder :
          <br />
    
          <ul id="stakholder">
          @foreach ( var stakerholder in ViewBag.stackholder )
          {          
        <li>
            @stakerholder.Key &nbsp; : @stakerholder.Value
        </li>
          }
         </ul>
       </div>
       <div>
         Project Details:<br />
         <div>
           module List  :
           <ul id="modulelist">
          @foreach ( var module in ViewBag.modules )
          {          
        <li>
            @module
        </li>
          }
         </ul>
            
         </div>
         Project StartDate : @ViewBag.StartDate.ToString("dd-MMM-yyyy") <br />
         Project TotalPrice: @ViewBag.TotalPrice  ₹  <br />
         Project TotaDays  : @ViewBag.TotalDays 
       </div>
     </div>
    

     

  • 相关阅读:
    CentOS7.2中安装MongoDB
    django 面试题
    python pandas库——pivot使用心得
    归并排序
    python实现归并排序,归并排序的详细分析
    二分法查找
    二叉树的遍历
    RabbitMQ(python实现)学习之一:简单两点传输“Hello World”的实现
    邻接表存储图,DFS遍历图的java代码实现
    五、python使用模块
  • 原文地址:https://www.cnblogs.com/tianguook/p/3959618.html
Copyright © 2011-2022 走看看