• MVC学习第四节 向View传值


     

    一、ViewData与TempData属性来向View页传递对象


    上文中已经提到,使用ViewData可以将数据由Controller传递到View 
    在前文中我们建立了EiceController类 
    在本文的示例中我们将这个Controller改一下

       public class EiceController : Controller
        {
            public ActionResult Index()
            {
                ViewData["ViewData"] = "在这里显示ViewData";
                TempData["TempData"] = "在这里显示TempData";
                return View();
            }
            public ActionResult Index2()
            {
                return View("Index");
                //这里指定了规定显示的View文件即Eice目录下的Index.aspx
            }
        }

    我们将Index的参数移除,并提供了ViewDataTempData的赋值 
    在Views/Eice/Index.aspx这个View中我们写以下代码

    1 <%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage" %>
    2 <asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
    3     Index
    4 </asp:Content>
    5 <asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
    6 1:<%=ViewData["ViewData"]%><br />
    7 2:<%=TempData["TempData"]%>
    8 </asp:Content>

    注意上面的1.2不是行号,是我写的。

    接下来我们运行工程 
    访问http://localhost/Eice/Index 
    可以看到运行得到以下

    1.在这里显示ViewData
    2.在这里显示TempData

    再访问http://localhost/Eice/Index2 
    显示结果为

    1.
    2.在这里显示TempData

    这里1显示是的ViewData中的内容,2为TempData传递的内容

    我们可以看到ViewData只能在当前Action中有效 
    但是TempData可以类似于Session一样到其它页面仍然存在,但只限一页的访问(类似于Monorail中的Flash) 
    TempData一般用于临时的缓存内容或抛出错误页面时传递错误信息。

    二、通过ViewData.Model来传递对象

    我们先建立一个Model:EiceIndexModel.cs。

     1     public class EiceIndexModel
     2     {
     3         /// <summary>
     4         /// 姓名
     5         /// </summary>
     6         public string Name { get; set; }
     7         /// <summary>
     8         /// 性别
     9         /// </summary>
    10         public bool  Sex { get; set; }
    11     }

    之后我们建立一个新的Action:Index3

    1         public ActionResult Index3(){
    2             var m = new EiceIndexModel
    3             {
    4                 Name = "邹健",
    5                 Sex = true
    6             };
    7             return View(m);
    8         }

    我们下面为Index3建立View文件,仍然是在Index3上点击右键AddView

    image

    于是自动生成了一个View文件,我们运行看结果:

    image

    如果我们想要显示其它的文件我们应该怎么办呢?

     
  • 相关阅读:
    arm-gcc 命名规则
    Ubuntu中安装最新 Node.js 和 npm
    Tutorial: Create a Blinky ARM test project(创建一个闪灯的arm测试项目)
    Tutorial: How to install GNU MCU Eclipse?
    操作系统有关概念
    移植 uCos-III 3.03 到 STM32F429 上
    Kubernetes工作原理
    Kubernetes基础特性
    nmap详解之原理与用法
    nmap详解之基础示例
  • 原文地址:https://www.cnblogs.com/ayzhanglei/p/2864789.html
Copyright © 2020-2023  润新知