zoukankan      html  css  js  c++  java
  • ASP.NET MVC之从控制器传递数据到视图四种方式

    前言

    本系列开始着手讲述ASP.NET MVC,也算是自己对基础的回顾以及进一步深入学习,保证每天发表一篇该系列文章,关于基本知识则不再叙述,园子有关文章不胜枚举,这一系列若有叙述不当或错误之处,欢迎指出以及批评。

    前奏

    新建基本项目在Models文件夹下定义如下类:

    复制代码
        public class Person
        {
            public int Id { get; set; }
    
            public string Name { get; set; }
    
            public string BlogAddress { get; set; }
    
            public string Description { get; set; }
        }
    复制代码

    我们在控制器的Action方法中实例化此类:

    复制代码
                var p = new Person()
                {
                    Id = 98,
                    Name = "xpy0928",
                    BlogAddress = "http://www.cnblogs.com/CreateMyself",
                    Description = "出生非贫即贵,你我无能为力,后天若不加以努力赶之超之,又能怪谁呢!自己都靠不住不靠谱,又能靠谁呢!"
                };
    复制代码

    方式1 (ViewData)

    我们利用ViewData以键值对的形式来存储上述实例化的对象,如下:

     ViewData["Person"] = p;

    在视图中我们从ViewData中获取存储的值并转换成对象,如下:

    @using ASP.NET_MVC_1.Models;
    
    @{
        var p = (Person)ViewData["Person"];
    }

    接着我们获取对象中的值:

    <h1>Person</h1>
    <h3>@p.Id</h3>
    <h3>@p.Name</h3>
    <h3>@p.BlogAddress</h3>
    <h3>@p.Description</h3>

    我们来看看是否获取到该对象的值,如下:

     方式2(ViewBag)

     将控制器Action方法以ViewBag创建动态表达式来进行,如下:

     ViewBag.Person = p;

    在视图中,我们进行如下修改:

    @using ASP.NET_MVC_1.Models;
    
    @{
        var p = ViewBag.Person as Person;
    }

    获取对象值同上,我们继续看看是否如我们所预想:

    方式3(Model) 

    我们通过控制器中返回的View方法进行传递该对象,如下:

    复制代码
                var p = new Person()
                {
                    Id = 98,
                    Name = "xpy0928",
                    BlogAddress = "http://www.cnblogs.com/CreateMyself",
                    Description = "出生非贫即贵,你我无能为力,后天若不加以努力赶之超之,又能怪谁呢!自己都靠不住不靠谱,又能靠谁呢!"
                };
                return View(p);
    复制代码

    此时视图中,我们将需要得到该强类型对象:

    @using ASP.NET_MVC_1.Models;
    
    @model Person;

    而获取对象的值则通过Model来获取,如下:

    <h1>Person</h1>
    <h3>@Model.Id</h3>
    <h3>@Model.Name</h3>
    <h3>@Model.BlogAddress</h3>
    <h3>@Model.Description</h3>

    毫无疑问结果依然如此:

    方式4(TempData) 

    从字面意思来理解我们会误认为是临时对象,好像就使用一次就不会再用了,确实是这样吗?很显然不是这样,当然其生命周期确实很短。该对象是将数据从一个控制器的方法传递到另外一个方法上。什么意思呢?我们想象这样一个场景:当我们在控制器的Info方法上添加一个Person的信息后,我们跳转到另外一个方法TempDataObject上来显示该对象已经成功被创建。

    下面我们来演示这种场景:

    复制代码
            public ActionResult Info()
            {
                var p = new Person()
                {
                    Id = 98,
                    Name = "xpy0928",
                    BlogAddress = "http://www.cnblogs.com/CreateMyself",
                    Description = "出生非贫即贵,你我无能为力,后天若不加以努力赶之超之,又能怪谁呢!自己都靠不住不靠谱,又能靠谁呢!"
                };
                //TODO 添加Person到数据库中
                TempData["info"] = "提示:已经成功添加一条数据到数据库中";
                return RedirectToAction("TempDataObject");
            }
    复制代码

    创建一个TempData方法,获取上面传递过来的值,如下:

            public ActionResult TempDataObject()
            {
                return View();
            }

    在方法对应的视图获取传递过来的值:

    <h1>@TempData["info"]</h1>

    我们通过访问Info,观察当跳转过来到该方法时后渲染视图是否能够获取到该值:

    当然在上述过程中这是利用将一个Action中的数据通过TempData传递到另外一个Action中,但是我们需注意,这是利用跳转到TempDataObject才会正确显示数据,如果我们直接刷新页面将会出现System.NullReferenceException。

  • 相关阅读:
    laravel tymon/jwt-auth header 发送token
    laravel migrate时报错:Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes
    laravel 报错 class not exist
    HTTP 状态码详解大全 | HTTP Status Codes
    JS,jquery 无法获取到动态插入的元素
    关键字
    PHP 配置默认SSL CA证书
    phpunit 配置
    plantuml 手册
    Windows使用RunHiddenConsole一键启动nginx,php-cgi服务
  • 原文地址:https://www.cnblogs.com/xinhuawei/p/5419314.html
Copyright © 2011-2022 走看看